Modifications for CCRX toolchain

This commit is contained in:
Roland
2022-02-01 23:45:52 +01:00
parent ffb257ac17
commit e1f0c484c6
2 changed files with 11 additions and 3 deletions

View File

@@ -75,7 +75,11 @@
* Nth position is the same as the number of arguments * Nth position is the same as the number of arguments
* - ##__VA_ARGS__ is used to deal with 0 paramerter (swallows comma) * - ##__VA_ARGS__ is used to deal with 0 paramerter (swallows comma)
*------------------------------------------------------------------*/ *------------------------------------------------------------------*/
#if !defined(__CCRX__)
#define TU_ARGS_NUM(...) _TU_NARG(_0, ##__VA_ARGS__,_RSEQ_N()) #define TU_ARGS_NUM(...) _TU_NARG(_0, ##__VA_ARGS__,_RSEQ_N())
#else
#define TU_ARGS_NUM(...) _TU_NARG(_0, __VA_ARGS__,_RSEQ_N())
#endif
#define _TU_NARG(...) _GET_NTH_ARG(__VA_ARGS__) #define _TU_NARG(...) _GET_NTH_ARG(__VA_ARGS__)
#define _GET_NTH_ARG( \ #define _GET_NTH_ARG( \

View File

@@ -494,7 +494,11 @@ static bool process_pipe_xfer(int buffer_type, uint8_t ep_addr, void* buffer, ui
while (USB0.D0FIFOSEL.BIT.CURPIPE) ; /* if CURPIPE bits changes, check written value */ while (USB0.D0FIFOSEL.BIT.CURPIPE) ; /* if CURPIPE bits changes, check written value */
} }
} else { } else {
#if defined(__CCRX__)
__evenaccess volatile reg_pipetre_t *pt = get_pipetre(num);
#else
volatile reg_pipetre_t *pt = get_pipetre(num); volatile reg_pipetre_t *pt = get_pipetre(num);
#endif
if (pt) { if (pt) {
const unsigned mps = edpt_max_packet_size(num); const unsigned mps = edpt_max_packet_size(num);
volatile uint16_t *ctr = get_pipectr(num); volatile uint16_t *ctr = get_pipectr(num);
@@ -715,11 +719,11 @@ bool dcd_edpt_open(uint8_t rhport, tusb_desc_endpoint_t const * ep_desc)
*ctr = 0; *ctr = 0;
unsigned cfg = (dir << 4) | epn; unsigned cfg = (dir << 4) | epn;
if (xfer == TUSB_XFER_BULK) { if (xfer == TUSB_XFER_BULK) {
cfg |= USB_PIPECFG_BULK | USB_PIPECFG_SHTNAK | USB_PIPECFG_DBLB; cfg |= (USB_PIPECFG_BULK | USB_PIPECFG_SHTNAK | USB_PIPECFG_DBLB);
} else if (xfer == TUSB_XFER_INTERRUPT) { } else if (xfer == TUSB_XFER_INTERRUPT) {
cfg |= USB_PIPECFG_INT; cfg |= USB_PIPECFG_INT;
} else { } else {
cfg |= USB_PIPECFG_ISO | USB_PIPECFG_DBLB; cfg |= (USB_PIPECFG_ISO | USB_PIPECFG_DBLB);
} }
USB0.PIPECFG.WORD = cfg; USB0.PIPECFG.WORD = cfg;
USB0.BRDYSTS.WORD = 0x1FFu ^ TU_BIT(num); USB0.BRDYSTS.WORD = 0x1FFu ^ TU_BIT(num);