fix fuzzing build

This commit is contained in:
hathach 2024-10-11 16:00:51 +07:00
parent d997f0071e
commit f3b7d7515e
No known key found for this signature in database
GPG Key ID: 26FAB84F615C3C52
8 changed files with 54 additions and 68 deletions

View File

@ -43,17 +43,17 @@ repos:
types_or: [c, header] types_or: [c, header]
language: system language: system
- id: build-fuzzer # - id: build-fuzzer
name: build-fuzzer # name: build-fuzzer
files: ^(src/|test/fuzz/) # files: ^(src/|test/fuzz/)
language: system # language: system
types_or: [c, header] # types_or: [c, header]
entry: | # entry: |
export CC=clang # bash -c 'export CC=clang
export CXX=clang++ # export CXX=clang++
fuzz_harness=$(ls -d test/fuzz/device/*/) # fuzz_harness=$(ls -d test/fuzz/device/*/)
for h in $fuzz_harness # for h in $fuzz_harness
do # do
make -C $h get-deps # make -C $h get-deps
make -C $h all # make -C $h all
done # done'

View File

@ -194,38 +194,45 @@ extern void dcd_event_handler(dcd_event_t const * event, bool in_isr);
// helper to send bus signal event // helper to send bus signal event
TU_ATTR_ALWAYS_INLINE static inline void dcd_event_bus_signal (uint8_t rhport, dcd_eventid_t eid, bool in_isr) { TU_ATTR_ALWAYS_INLINE static inline void dcd_event_bus_signal (uint8_t rhport, dcd_eventid_t eid, bool in_isr) {
dcd_event_t event = { .rhport = rhport, .event_id = eid }; dcd_event_t event;
event.rhport = rhport;
event.event_id = eid;
dcd_event_handler(&event, in_isr); dcd_event_handler(&event, in_isr);
} }
// helper to send bus reset event // helper to send bus reset event
TU_ATTR_ALWAYS_INLINE static inline void dcd_event_bus_reset (uint8_t rhport, tusb_speed_t speed, bool in_isr) { TU_ATTR_ALWAYS_INLINE static inline void dcd_event_bus_reset (uint8_t rhport, tusb_speed_t speed, bool in_isr) {
dcd_event_t event = { .rhport = rhport, .event_id = DCD_EVENT_BUS_RESET }; dcd_event_t event;
event.rhport = rhport;
event.event_id = DCD_EVENT_BUS_RESET;
event.bus_reset.speed = speed; event.bus_reset.speed = speed;
dcd_event_handler(&event, in_isr); dcd_event_handler(&event, in_isr);
} }
// helper to send setup received // helper to send setup received
TU_ATTR_ALWAYS_INLINE static inline void dcd_event_setup_received(uint8_t rhport, uint8_t const * setup, bool in_isr) { TU_ATTR_ALWAYS_INLINE static inline void dcd_event_setup_received(uint8_t rhport, uint8_t const * setup, bool in_isr) {
dcd_event_t event = { .rhport = rhport, .event_id = DCD_EVENT_SETUP_RECEIVED }; dcd_event_t event;
event.rhport = rhport;
event.event_id = DCD_EVENT_SETUP_RECEIVED;
memcpy(&event.setup_received, setup, sizeof(tusb_control_request_t)); memcpy(&event.setup_received, setup, sizeof(tusb_control_request_t));
dcd_event_handler(&event, in_isr); dcd_event_handler(&event, in_isr);
} }
// helper to send transfer complete event // helper to send transfer complete event
TU_ATTR_ALWAYS_INLINE static inline void dcd_event_xfer_complete (uint8_t rhport, uint8_t ep_addr, uint32_t xferred_bytes, uint8_t result, bool in_isr) { TU_ATTR_ALWAYS_INLINE static inline void dcd_event_xfer_complete (uint8_t rhport, uint8_t ep_addr, uint32_t xferred_bytes, uint8_t result, bool in_isr) {
dcd_event_t event = { .rhport = rhport, .event_id = DCD_EVENT_XFER_COMPLETE }; dcd_event_t event;
event.rhport = rhport;
event.event_id = DCD_EVENT_XFER_COMPLETE;
event.xfer_complete.ep_addr = ep_addr; event.xfer_complete.ep_addr = ep_addr;
event.xfer_complete.len = xferred_bytes; event.xfer_complete.len = xferred_bytes;
event.xfer_complete.result = result; event.xfer_complete.result = result;
dcd_event_handler(&event, in_isr); dcd_event_handler(&event, in_isr);
} }
TU_ATTR_ALWAYS_INLINE static inline void dcd_event_sof(uint8_t rhport, uint32_t frame_count, bool in_isr) { TU_ATTR_ALWAYS_INLINE static inline void dcd_event_sof(uint8_t rhport, uint32_t frame_count, bool in_isr) {
dcd_event_t event = { .rhport = rhport, .event_id = DCD_EVENT_SOF }; dcd_event_t event;
event.rhport = rhport;
event.event_id = DCD_EVENT_SOF;
event.sof.frame_count = frame_count; event.sof.frame_count = frame_count;
dcd_event_handler(&event, in_isr); dcd_event_handler(&event, in_isr);
} }

View File

@ -78,9 +78,8 @@ static void bus_reset(void)
/*------------------------------------------------------------------*/ /*------------------------------------------------------------------*/
/* Controller API /* Controller API
*------------------------------------------------------------------*/ *------------------------------------------------------------------*/
void dcd_init (uint8_t rhport) void dcd_init(const tusb_rhport_init_t* rh_init) {
{ (void) rh_init;
(void) rhport;
// Reset to get in a clean state. // Reset to get in a clean state.
USB->DEVICE.CTRLA.bit.SWRST = true; USB->DEVICE.CTRLA.bit.SWRST = true;

View File

@ -155,8 +155,8 @@ static void bus_reset(void)
} }
// Initialize controller to device mode // Initialize controller to device mode
void dcd_init (uint8_t rhport) void dcd_init(const tusb_rhport_init_t* rh_init) {
{ const uint8_t rhport = rh_init->rhport;
tu_memclr(_dcd_xfer, sizeof(_dcd_xfer)); tu_memclr(_dcd_xfer, sizeof(_dcd_xfer));
dcd_connect(rhport); dcd_connect(rhport);
} }

View File

@ -104,8 +104,8 @@ TU_ATTR_ALWAYS_INLINE static inline void CleanInValidateCache(uint32_t *addr, in
//------------------------------------------------------------------ //------------------------------------------------------------------
// Initialize controller to device mode // Initialize controller to device mode
void dcd_init (uint8_t rhport) void dcd_init(const tusb_rhport_init_t* rh_init) {
{ const uint8_t rhport = rh_init->rhport;
dcd_connect(rhport); dcd_connect(rhport);
} }

View File

@ -50,10 +50,8 @@ static usb_descriptor_buffers_t desc;
*------------------------------------------------------------------*/ *------------------------------------------------------------------*/
// Initialize controller to device mode // Initialize controller to device mode
void dcd_init (uint8_t rhport) void dcd_init(const tusb_rhport_init_t* rh_init) {
{ (void) rh_init;
(void) rhport;
static pio_usb_configuration_t config = PIO_USB_DEFAULT_CONFIG; static pio_usb_configuration_t config = PIO_USB_DEFAULT_CONFIG;
usb_device = pio_usb_device_init(&config, &desc); usb_device = pio_usb_device_init(&config, &desc);
} }

View File

@ -40,54 +40,44 @@
*------------------------------------------------------------------*/ *------------------------------------------------------------------*/
// Initialize controller to device mode // Initialize controller to device mode
void dcd_init (uint8_t rhport) void dcd_init(const tusb_rhport_init_t* rh_init) {
{ (void) rh_init;
(void) rhport;
} }
// Enable device interrupt // Enable device interrupt
void dcd_int_enable (uint8_t rhport) void dcd_int_enable (uint8_t rhport) {
{
(void) rhport; (void) rhport;
} }
// Disable device interrupt // Disable device interrupt
void dcd_int_disable (uint8_t rhport) void dcd_int_disable (uint8_t rhport) {
{
(void) rhport; (void) rhport;
} }
// Receive Set Address request, mcu port must also include status IN response // Receive Set Address request, mcu port must also include status IN response
void dcd_set_address (uint8_t rhport, uint8_t dev_addr) void dcd_set_address (uint8_t rhport, uint8_t dev_addr) {
{
(void) rhport; (void) rhport;
(void) dev_addr; (void) dev_addr;
} }
// Wake up host // Wake up host
void dcd_remote_wakeup (uint8_t rhport) void dcd_remote_wakeup (uint8_t rhport) {
{
(void) rhport; (void) rhport;
} }
// Connect by enabling internal pull-up resistor on D+/D- // Connect by enabling internal pull-up resistor on D+/D-
void dcd_connect(uint8_t rhport) void dcd_connect(uint8_t rhport) {
{
(void) rhport; (void) rhport;
} }
// Disconnect by disabling internal pull-up resistor on D+/D- // Disconnect by disabling internal pull-up resistor on D+/D-
void dcd_disconnect(uint8_t rhport) void dcd_disconnect(uint8_t rhport) {
{
(void) rhport; (void) rhport;
} }
void dcd_sof_enable(uint8_t rhport, bool en) void dcd_sof_enable(uint8_t rhport, bool en) {
{
(void) rhport; (void) rhport;
(void) en; (void) en;
// TODO implement later
} }
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
@ -95,8 +85,7 @@ void dcd_sof_enable(uint8_t rhport, bool en)
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// Configure endpoint's registers according to descriptor // Configure endpoint's registers according to descriptor
bool dcd_edpt_open (uint8_t rhport, tusb_desc_endpoint_t const * ep_desc) bool dcd_edpt_open (uint8_t rhport, tusb_desc_endpoint_t const * ep_desc) {
{
(void) rhport; (void) rhport;
(void) ep_desc; (void) ep_desc;
return false; return false;
@ -118,14 +107,12 @@ bool dcd_edpt_iso_activate(uint8_t rhport, tusb_desc_endpoint_t const * desc_ep)
return false; return false;
} }
void dcd_edpt_close_all (uint8_t rhport) void dcd_edpt_close_all (uint8_t rhport) {
{
(void) rhport; (void) rhport;
} }
// Submit a transfer, When complete dcd_event_xfer_complete() is invoked to notify the stack // Submit a transfer, When complete dcd_event_xfer_complete() is invoked to notify the stack
bool dcd_edpt_xfer (uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes) bool dcd_edpt_xfer (uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes) {
{
(void) rhport; (void) rhport;
(void) ep_addr; (void) ep_addr;
(void) buffer; (void) buffer;
@ -134,8 +121,7 @@ bool dcd_edpt_xfer (uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t
} }
// Submit a transfer where is managed by FIFO, When complete dcd_event_xfer_complete() is invoked to notify the stack - optional, however, must be listed in usbd.c // Submit a transfer where is managed by FIFO, When complete dcd_event_xfer_complete() is invoked to notify the stack - optional, however, must be listed in usbd.c
bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16_t total_bytes) bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16_t total_bytes) {
{
(void) rhport; (void) rhport;
(void) ep_addr; (void) ep_addr;
(void) ff; (void) ff;
@ -144,19 +130,15 @@ bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16
} }
// Stall endpoint // Stall endpoint
void dcd_edpt_stall (uint8_t rhport, uint8_t ep_addr) void dcd_edpt_stall (uint8_t rhport, uint8_t ep_addr) {
{
(void) rhport; (void) rhport;
(void) ep_addr; (void) ep_addr;
} }
// clear stall, data toggle is also reset to DATA0 // clear stall, data toggle is also reset to DATA0
void dcd_edpt_clear_stall (uint8_t rhport, uint8_t ep_addr) void dcd_edpt_clear_stall (uint8_t rhport, uint8_t ep_addr) {
{
(void) rhport; (void) rhport;
(void) ep_addr; (void) ep_addr;
} }
#endif #endif

View File

@ -46,8 +46,8 @@ tu_static State state = {false, 0, 0};
// All no-ops as we are fuzzing. // All no-ops as we are fuzzing.
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
extern "C" { extern "C" {
void dcd_init(uint8_t rhport) { void dcd_init(const tusb_rhport_init_t* rh_init) {
UNUSED(rhport); UNUSED(rh_init);
return; return;
} }