allow application driver to overwrite built-in one

- position application driver before built-in
- remove dcd.h from public include.
This commit is contained in:
hathach 2020-08-07 14:47:32 +07:00
parent 9df8057702
commit 01b9b77d3b
4 changed files with 31 additions and 34 deletions

View File

@ -31,6 +31,7 @@
#include "common/tusb_common.h" #include "common/tusb_common.h"
#include "msc_device.h" #include "msc_device.h"
#include "device/usbd_pvt.h" #include "device/usbd_pvt.h"
#include "device/dcd.h" // for faking dcd_event_xfer_complete
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// MACRO CONSTANT TYPEDEF // MACRO CONSTANT TYPEDEF

View File

@ -80,7 +80,6 @@
#include <string.h> #include <string.h>
#include "usbtmc.h" #include "usbtmc.h"
#include "usbtmc_device.h" #include "usbtmc_device.h"
#include "device/dcd.h"
#include "device/usbd.h" #include "device/usbd.h"
#include "osal/osal.h" #include "osal/osal.h"

View File

@ -203,30 +203,30 @@ static usbd_class_driver_t const _usbd_driver[] =
#endif #endif
}; };
enum { USBD_CLASS_DRIVER_COUNT = TU_ARRAY_SIZE(_usbd_driver) }; enum { BUILTIN_DRIVER_COUNT = TU_ARRAY_SIZE(_usbd_driver) };
// Additional class drivers implemented by application // Additional class drivers implemented by application
static usbd_class_driver_t const * _app_driver = NULL; static usbd_class_driver_t const * _app_driver = NULL;
static uint8_t _app_driver_count = 0; static uint8_t _app_driver_count = 0;
// virtually joins built-in and application drivers together // virtually joins built-in and application drivers together.
// All drivers = built-in + application // Application is positioned first to allow overwriting built-in ones.
static inline usbd_class_driver_t const * get_driver(uint8_t drvid) static inline usbd_class_driver_t const * get_driver(uint8_t drvid)
{ {
// Built-in drivers // Application drivers
if (drvid < USBD_CLASS_DRIVER_COUNT) return &_usbd_driver[drvid];
// App drivers
if ( usbd_app_driver_get_cb ) if ( usbd_app_driver_get_cb )
{ {
drvid -= USBD_CLASS_DRIVER_COUNT;
if ( drvid < _app_driver_count ) return &_app_driver[drvid]; if ( drvid < _app_driver_count ) return &_app_driver[drvid];
drvid -= _app_driver_count;
} }
// Built-in drivers
if (drvid < BUILTIN_DRIVER_COUNT) return &_usbd_driver[drvid];
return NULL; return NULL;
} }
#define TOTAL_DRIVER_COUNT (USBD_CLASS_DRIVER_COUNT+_app_driver_count) #define TOTAL_DRIVER_COUNT (_app_driver_count + BUILTIN_DRIVER_COUNT)
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// DCD Event // DCD Event
@ -245,6 +245,7 @@ static bool process_control_request(uint8_t rhport, tusb_control_request_t const
static bool process_set_config(uint8_t rhport, uint8_t cfg_num); static bool process_set_config(uint8_t rhport, uint8_t cfg_num);
static bool process_get_descriptor(uint8_t rhport, tusb_control_request_t const * p_request); static bool process_get_descriptor(uint8_t rhport, tusb_control_request_t const * p_request);
// from usbd_control.c
void usbd_control_reset(void); void usbd_control_reset(void);
void usbd_control_set_request(tusb_control_request_t const *request); void usbd_control_set_request(tusb_control_request_t const *request);
void usbd_control_set_complete_callback( bool (*fp) (uint8_t, tusb_control_request_t const * ) ); void usbd_control_set_complete_callback( bool (*fp) (uint8_t, tusb_control_request_t const * ) );
@ -252,7 +253,7 @@ bool usbd_control_xfer_cb (uint8_t rhport, uint8_t ep_addr, xfer_result_t event,
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// Debugging // Debug
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
#if CFG_TUSB_DEBUG >= 2 #if CFG_TUSB_DEBUG >= 2
static char const* const _usbd_event_str[DCD_EVENT_COUNT] = static char const* const _usbd_event_str[DCD_EVENT_COUNT] =
@ -327,6 +328,20 @@ bool tud_remote_wakeup(void)
return true; return true;
} }
bool tud_disconnect(void)
{
TU_VERIFY(dcd_disconnect);
dcd_disconnect(TUD_OPT_RHPORT);
return true;
}
bool tud_connect(void)
{
TU_VERIFY(dcd_connect);
dcd_connect(TUD_OPT_RHPORT);
return true;
}
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// USBD Task // USBD Task
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
@ -593,7 +608,6 @@ static bool process_control_request(uint8_t rhport, tusb_control_request_t const
uint8_t const cfg_num = (uint8_t) p_request->wValue; uint8_t const cfg_num = (uint8_t) p_request->wValue;
if ( !_usbd_dev.configured && cfg_num ) TU_ASSERT( process_set_config(rhport, cfg_num) ); if ( !_usbd_dev.configured && cfg_num ) TU_ASSERT( process_set_config(rhport, cfg_num) );
_usbd_dev.configured = cfg_num ? 1 : 0; _usbd_dev.configured = cfg_num ? 1 : 0;
tud_control_status(rhport, p_request); tud_control_status(rhport, p_request);
@ -688,18 +702,12 @@ static bool process_control_request(uint8_t rhport, tusb_control_request_t const
break; break;
case TUSB_REQ_CLEAR_FEATURE: case TUSB_REQ_CLEAR_FEATURE:
if ( TUSB_REQ_FEATURE_EDPT_HALT == p_request->wValue ) if ( TUSB_REQ_FEATURE_EDPT_HALT == p_request->wValue ) usbd_edpt_clear_stall(rhport, ep_addr);
{
usbd_edpt_clear_stall(rhport, ep_addr);
}
tud_control_status(rhport, p_request); tud_control_status(rhport, p_request);
break; break;
case TUSB_REQ_SET_FEATURE: case TUSB_REQ_SET_FEATURE:
if ( TUSB_REQ_FEATURE_EDPT_HALT == p_request->wValue ) if ( TUSB_REQ_FEATURE_EDPT_HALT == p_request->wValue ) usbd_edpt_stall(rhport, ep_addr);
{
usbd_edpt_stall(rhport, ep_addr);
}
tud_control_status(rhport, p_request); tud_control_status(rhport, p_request);
break; break;
@ -773,7 +781,6 @@ static bool process_set_config(uint8_t rhport, uint8_t cfg_num)
for (drv_id = 0; drv_id < TOTAL_DRIVER_COUNT; drv_id++) for (drv_id = 0; drv_id < TOTAL_DRIVER_COUNT; drv_id++)
{ {
usbd_class_driver_t const *driver = get_driver(drv_id); usbd_class_driver_t const *driver = get_driver(drv_id);
uint16_t const drv_len = driver->open(rhport, desc_itf, remaining_len); uint16_t const drv_len = driver->open(rhport, desc_itf, remaining_len);
if ( drv_len > 0 ) if ( drv_len > 0 )

View File

@ -35,7 +35,6 @@
#endif #endif
#include "common/tusb_common.h" #include "common/tusb_common.h"
#include "dcd.h"
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// Application API // Application API
@ -53,6 +52,7 @@ void tud_task (void);
bool tud_task_event_ready(void); bool tud_task_event_ready(void);
// Interrupt handler, name alias to DCD // Interrupt handler, name alias to DCD
extern void dcd_int_handler(uint8_t rhport);
#define tud_int_handler dcd_int_handler #define tud_int_handler dcd_int_handler
// Get current bus speed // Get current bus speed
@ -75,21 +75,11 @@ bool tud_remote_wakeup(void);
// Enable pull-up resistor on D+ D- // Enable pull-up resistor on D+ D-
// Return false on unsupported MCUs // Return false on unsupported MCUs
static inline bool tud_disconnect(void) bool tud_disconnect(void);
{
TU_VERIFY(dcd_disconnect);
dcd_disconnect(TUD_OPT_RHPORT);
return true;
}
// Disable pull-up resistor on D+ D- // Disable pull-up resistor on D+ D-
// Return false on unsupported MCUs // Return false on unsupported MCUs
static inline bool tud_connect(void) bool tud_connect(void);
{
TU_VERIFY(dcd_connect);
dcd_connect(TUD_OPT_RHPORT);
return true;
}
// Carry out Data and Status stage of control transfer // Carry out Data and Status stage of control transfer
// - If len = 0, it is equivalent to sending status only // - If len = 0, it is equivalent to sending status only