52 #ifndef __GR55xx_LL_USB_H__
53 #define __GR55xx_LL_USB_H__
76 typedef struct _ll_usb_init_t
107 #define LL_USB_PWR_MODE_LP (0UL)
108 #define LL_USB_PWR_MODE_NORMAL (1UL)
115 #define LL_USB_ENUM_TYPE_HW (0x00000000UL)
116 #define LL_USB_ENUM_TYPE_MCU (1UL << USB_CTRL_MCU_ENUM_Pos)
123 #define LL_USB_TRX_LDO_BIAS_SEL0 (0x00000000UL)
124 #define LL_USB_TRX_LDO_BIAS_SEL1 (1UL << AON_PMU_USB_TRX_LDO_BIAS_SEL_Pos)
125 #define LL_USB_TRX_LDO_BIAS_SEL2 (2UL << AON_PMU_USB_TRX_LDO_BIAS_SEL_Pos)
126 #define LL_USB_TRX_LDO_BIAS_SEL3 (3UL << AON_PMU_USB_TRX_LDO_BIAS_SEL_Pos)
127 #define LL_USB_TRX_LDO_BIAS_SEL4 (4UL << AON_PMU_USB_TRX_LDO_BIAS_SEL_Pos)
128 #define LL_USB_TRX_LDO_BIAS_SEL5 (5UL << AON_PMU_USB_TRX_LDO_BIAS_SEL_Pos)
129 #define LL_USB_TRX_LDO_BIAS_SEL6 (6UL << AON_PMU_USB_TRX_LDO_BIAS_SEL_Pos)
130 #define LL_USB_TRX_LDO_BIAS_SEL7 (7UL << AON_PMU_USB_TRX_LDO_BIAS_SEL_Pos)
137 #define LL_USB_TRX_LDO_VSEL0 (0x00000000UL)
138 #define LL_USB_TRX_LDO_VSEL1 (1UL << AON_PMU_USB_TRX_LDO_VSEL_Pos)
139 #define LL_USB_TRX_LDO_VSEL2 (2UL << AON_PMU_USB_TRX_LDO_VSEL_Pos)
140 #define LL_USB_TRX_LDO_VSEL3 (3UL << AON_PMU_USB_TRX_LDO_VSEL_Pos)
141 #define LL_USB_TRX_LDO_VSEL4 (4UL << AON_PMU_USB_TRX_LDO_VSEL_Pos)
142 #define LL_USB_TRX_LDO_VSEL5 (5UL << AON_PMU_USB_TRX_LDO_VSEL_Pos)
143 #define LL_USB_TRX_LDO_VSEL6 (6UL << AON_PMU_USB_TRX_LDO_VSEL_Pos)
144 #define LL_USB_TRX_LDO_VSEL7 (7UL << AON_PMU_USB_TRX_LDO_VSEL_Pos)
150 #define LL_USB_XCRV_CTRL_SPEED_LOW (0x00000000UL)
151 #define LL_USB_XCRV_CTRL_SPEED_FULL (1UL << MCU_SUB_USB_XCRV_CTRL_SPEED_Pos)
157 #define LL_USB_XCRV_CTRL_RTRIMN0 (0x00000000UL)
158 #define LL_USB_XCRV_CTRL_RTRIMN1 (1UL << MCU_SUB_USB_XCRV_CTRL_RTRIMN_Pos)
159 #define LL_USB_XCRV_CTRL_RTRIMN2 (2UL << MCU_SUB_USB_XCRV_CTRL_RTRIMN_Pos)
160 #define LL_USB_XCRV_CTRL_RTRIMN3 (3UL << MCU_SUB_USB_XCRV_CTRL_RTRIMN_Pos)
161 #define LL_USB_XCRV_CTRL_RTRIMN4 (4UL << MCU_SUB_USB_XCRV_CTRL_RTRIMN_Pos)
162 #define LL_USB_XCRV_CTRL_RTRIMN5 (5UL << MCU_SUB_USB_XCRV_CTRL_RTRIMN_Pos)
163 #define LL_USB_XCRV_CTRL_RTRIMN6 (6UL << MCU_SUB_USB_XCRV_CTRL_RTRIMN_Pos)
164 #define LL_USB_XCRV_CTRL_RTRIMN7 (7UL << MCU_SUB_USB_XCRV_CTRL_RTRIMN_Pos)
170 #define LL_USB_XCRV_CTRL_RTRIMP0 (0x00000000UL)
171 #define LL_USB_XCRV_CTRL_RTRIMP1 (1UL << MCU_SUB_USB_XCRV_CTRL_RTRIMP_Pos)
172 #define LL_USB_XCRV_CTRL_RTRIMP2 (2UL << MCU_SUB_USB_XCRV_CTRL_RTRIMP_Pos)
173 #define LL_USB_XCRV_CTRL_RTRIMP3 (3UL << MCU_SUB_USB_XCRV_CTRL_RTRIMP_Pos)
174 #define LL_USB_XCRV_CTRL_RTRIMP4 (4UL << MCU_SUB_USB_XCRV_CTRL_RTRIMP_Pos)
175 #define LL_USB_XCRV_CTRL_RTRIMP5 (5UL << MCU_SUB_USB_XCRV_CTRL_RTRIMP_Pos)
176 #define LL_USB_XCRV_CTRL_RTRIMP6 (6UL << MCU_SUB_USB_XCRV_CTRL_RTRIMP_Pos)
177 #define LL_USB_XCRV_CTRL_RTRIMP7 (7UL << MCU_SUB_USB_XCRV_CTRL_RTRIMP_Pos)
183 #define LL_USB_EP_ATTR_EP1_INT (0x00000000UL)
184 #define LL_USB_EP_ATTR_EP1_ISO (1UL << USB_EP_ATTR_EP1_Pos)
185 #define LL_USB_EP_ATTR_EP1_BULK (2UL << USB_EP_ATTR_EP1_Pos)
191 #define LL_USB_EP_ATTR_EP2_INT (0x00000000UL)
192 #define LL_USB_EP_ATTR_EP2_ISO (1UL << USB_EP_ATTR_EP2_Pos)
193 #define LL_USB_EP_ATTR_EP2_BULK (2UL << USB_EP_ATTR_EP2_Pos)
199 #define LL_USB_EP_ATTR_EP3_INT (0x00000000UL)
200 #define LL_USB_EP_ATTR_EP3_ISO (1UL << USB_EP_ATTR_EP3_Pos)
201 #define LL_USB_EP_ATTR_EP3_BULK (2UL << USB_EP_ATTR_EP3_Pos)
207 #define LL_USB_INT_STAT_ALL USB_INT_STAT_ALL
208 #define LL_USB_INT_STAT_SUSPEND USB_INT_STAT_SUSPEND
209 #define LL_USB_INT_STAT_EP0_OUT_READY USB_INT_STAT_EP0_OUT_READY
210 #define LL_USB_INT_STAT_EP1_OUT_READY USB_INT_STAT_EP1_OUT_READY
211 #define LL_USB_INT_STAT_CRC16_ERR USB_INT_STAT_CRC16_ERR
212 #define LL_USB_INT_STAT_UPID_ERR USB_INT_STAT_UPID_ERR
213 #define LL_USB_INT_STAT_TIMEOUT_ERR USB_INT_STAT_TIMEOUT_ERR
214 #define LL_USB_INT_STAT_SEQ_ERR USB_INT_STAT_SEQ_ERR
215 #define LL_USB_INT_STAT_PID_CKS_ERR USB_INT_STAT_PID_CKS_ERR
216 #define LL_USB_INT_STAT_PID_CRC_ERR USB_INT_STAT_PID_CRC_ERR
217 #define LL_USB_INT_STAT_HOST_RESET USB_INT_STAT_HOST_RESET
218 #define LL_USB_INT_STAT_AHB_XFER_ERR USB_INT_STAT_AHB_XFER_ERR
219 #define LL_USB_INT_STAT_NSE_ERR USB_INT_STAT_NSE_ERR
220 #define LL_USB_INT_STAT_EP3_AHB_XFER_DONE USB_INT_STAT_EP3_AHB_XFER_DONE
221 #define LL_USB_INT_STAT_SYNC_ERR USB_INT_STAT_SYNC_ERR
222 #define LL_USB_INT_STAT_BIT_STUFF_ERR USB_INT_STAT_BIT_STUFF_ERR
223 #define LL_USB_INT_STAT_BYTE_ERR USB_INT_STAT_BYTE_ERR
224 #define LL_USB_INT_STAT_SOF USB_INT_STAT_SOF
225 #define LL_USB_INT_STAT_EP0_TX_DONE USB_INT_STAT_EP0_TX_DONE
226 #define LL_USB_INT_STAT_EP2_TX_DONE USB_INT_STAT_EP2_TX_DONE
227 #define LL_USB_INT_STAT_EP3_TX_DONE USB_INT_STAT_EP3_TX_DONE
228 #define LL_USB_INT_STAT_INTO_CONFIG USB_INT_STAT_INTO_CONFIG
229 #define LL_USB_INT_STAT_EP5_OUT_READY USB_INT_STAT_EP5_OUT_READY
230 #define LL_USB_INT_STAT_EP4_AHB_XFER_DONE USB_INT_STAT_EP4_AHB_XFER_DONE
231 #define LL_USB_INT_STAT_EP4_TX_DONE USB_INT_STAT_EP4_TX_DONE
232 #define LL_USB_INT_STAT_EP5_AHB_XFER_DONE USB_INT_STAT_EP5_AHB_XFER_DONE
233 #define LL_USB_INT_STAT_EP5_TIMER_OUT_ERR USB_INT_STAT_EP5_TIMER_OUT_ERR
239 #define LL_USB_INT_EN_ALL USB_INT_EN_ALL
240 #define LL_USB_INT_RESET_VAL USB_INT_EN_RESET_VAL
241 #define LL_USB_INT_EN_SUSPEND USB_INT_EN_SUSPEND
242 #define LL_USB_INT_EN_EP0_OUT_READY USB_INT_EN_EP0_OUT_READY
243 #define LL_USB_INT_EN_EP1_OUT_READY USB_INT_EN_EP1_OUT_READY
244 #define LL_USB_INT_EN_CRC16_ERR USB_INT_EN_CRC16_ERR
245 #define LL_USB_INT_EN_UPID_ERR USB_INT_EN_UPID_ERR
246 #define LL_USB_INT_EN_TIMEOUT_ERR USB_INT_EN_TIMEOUT_ERR
247 #define LL_USB_INT_EN_SEQ_ERR USB_INT_EN_SEQ_ERR
248 #define LL_USB_INT_EN_PID_CKS_ERR USB_INT_EN_PID_CKS_ERR
249 #define LL_USB_INT_EN_PID_CRC_ERR USB_INT_EN_PID_CRC_ERR
250 #define LL_USB_INT_EN_HOST_RESET USB_INT_EN_HOST_RESET
251 #define LL_USB_INT_EN_AHB_XFER_ERR USB_INT_EN_AHB_XFER_ERR
252 #define LL_USB_INT_EN_NSE_ERR USB_INT_EN_NSE_ERR
253 #define LL_USB_INT_EN_EP3_AHB_XFER_DONE USB_INT_EN_EP3_AHB_XFER_DONE
254 #define LL_USB_INT_EN_SYNC_ERR USB_INT_EN_SYNC_ERR
255 #define LL_USB_INT_EN_BIT_STUFF_ERR USB_INT_EN_BIT_STUFF_ERR
256 #define LL_USB_INT_EN_BYTE_ERR USB_INT_EN_BYTE_ERR
257 #define LL_USB_INT_EN_SOF USB_INT_EN_SOF
258 #define LL_USB_INT_EN_EP0_TX_DONE USB_INT_EN_EP0_TX_DONE
259 #define LL_USB_INT_EN_EP2_TX_DONE USB_INT_EN_EP2_TX_DONE
260 #define LL_USB_INT_EN_EP3_TX_DONE USB_INT_EN_EP3_TX_DONE
261 #define LL_USB_INT_EN_INTO_CONFIG USB_INT_EN_INTO_CONFIG
262 #define LL_USB_INT_EN_EP5_OUT_READY USB_INT_EN_EP5_OUT_READY
263 #define LL_USB_INT_EN_EP4_AHB_XFER_DONE USB_INT_EN_EP4_AHB_XFER_DONE
264 #define LL_USB_INT_EN_EP4_TX_DONE USB_INT_EN_EP4_TX_DONE
265 #define LL_USB_INT_EN_EP5_AHB_XFER_DONE USB_INT_EN_EP5_AHB_XFER_DONE
266 #define LL_USB_INT_EN_EP5_TIMER_OUT_ERR USB_INT_EN_EP5_TIMER_OUT_ERR
272 #define LL_USB_INT_CLR_ALL USB_INT_CLR_ALL
273 #define LL_USB_INT_CLR_SUSPEND USB_INT_CLR_SUSPEND
274 #define LL_USB_INT_CLR_EP0_OUT_READY USB_INT_CLR_EP0_OUT_READY
275 #define LL_USB_INT_CLR_EP1_OUT_READY USB_INT_CLR_EP1_OUT_READY
276 #define LL_USB_INT_CLR_CRC16_ERR USB_INT_CLR_CRC16_ERR
277 #define LL_USB_INT_CLR_UPID_ERR USB_INT_CLR_UPID_ERR
278 #define LL_USB_INT_CLR_TIMEOUT_ERR USB_INT_CLR_TIMEOUT_ERR
279 #define LL_USB_INT_CLR_SEQ_ERR USB_INT_CLR_SEQ_ERR
280 #define LL_USB_INT_CLR_PID_CKS_ERR USB_INT_CLR_PID_CKS_ERR
281 #define LL_USB_INT_CLR_PID_CRC_ERR USB_INT_CLR_PID_CRC_ERR
282 #define LL_USB_INT_CLR_HOST_RESET USB_INT_CLR_HOST_RESET
283 #define LL_USB_INT_CLR_AHB_XFER_ERR USB_INT_CLR_AHB_XFER_ERR
284 #define LL_USB_INT_CLR_NSE_ERR USB_INT_CLR_NSE_ERR
285 #define LL_USB_INT_CLR_EP3_AHB_XFER_DONE USB_INT_CLR_EP3_AHB_XFER_DONE
286 #define LL_USB_INT_CLR_SYNC_ERR USB_INT_CLR_SYNC_ERR
287 #define LL_USB_INT_CLR_BIT_STUFF_ERR USB_INT_CLR_BIT_STUFF_ERR
288 #define LL_USB_INT_CLR_BYTE_ERR USB_INT_CLR_BYTE_ERR
289 #define LL_USB_INT_CLR_SOF USB_INT_CLR_SOF
290 #define LL_USB_INT_CLR_EP0_TX_DONE USB_INT_CLR_EP0_TX_DONE
291 #define LL_USB_INT_CLR_EP2_TX_DONE USB_INT_CLR_EP2_TX_DONE
292 #define LL_USB_INT_CLR_EP3_TX_DONE USB_INT_CLR_EP3_TX_DONE
293 #define LL_USB_INT_CLR_INTO_CONFIG USB_INT_CLR_INTO_CONFIG
294 #define LL_USB_INT_CLR_EP5_OUT_READY USB_INT_CLR_EP5_OUT_READY
295 #define LL_USB_INT_CLR_EP4_AHB_XFER_DONE USB_INT_CLR_EP4_AHB_XFER_DONE
296 #define LL_USB_INT_CLR_EP4_TX_DONE USB_INT_CLR_EP4_TX_DONE
297 #define LL_USB_INT_CLR_EP5_AHB_XFER_DONE USB_INT_CLR_EP5_AHB_XFER_DONE
298 #define LL_USB_INT_CLR_EP5_TIMER_OUT_ERR USB_INT_CLR_EP5_TIMER_OUT_ERR
304 #define LL_USB_CTRL0_OUTPUT_ENDIAN_CTRL_SMALL (0x00000000UL)
305 #define LL_USB_CTRL0_OUTPUT_ENDIAN_CTRL_BIG (1UL << USB_CTRL0_OUTPUT_ENDIAN_CTRL_Pos)
311 #define LL_USB_CTRL0_INPUT_ENDIAN_CTRL_SMALL (0x00000000UL)
312 #define LL_USB_CTRL0_INPUT_ENDIAN_CTRL_BIG (1UL << USB_CTRL0_INPUT_ENDIAN_CTRL_Pos)
318 #define LL_USB_CTRL0_PROBE_SEL_PROTOCAL_STAT (0x00000000UL)
319 #define LL_USB_CTRL0_PROBE_SEL_RX_STAT (1UL << USB_CTRL0_PROBE_SEL_Pos)
320 #define LL_USB_CTRL0_PROBE_SEL_UTMI_SIGNALS (2UL << USB_CTRL0_PROBE_SEL_Pos)
321 #define LL_USB_CTRL0_PROBE_SEL_SYNC_STAT (3UL << USB_CTRL0_PROBE_SEL_Pos)
322 #define LL_USB_CTRL0_PROBE_SEL_TX_STAT (4UL << USB_CTRL0_PROBE_SEL_Pos)
323 #define LL_USB_CTRL0_PROBE_SEL_DPLL_STAT (5UL << USB_CTRL0_PROBE_SEL_Pos)
329 #define LL_USB_EP4_FIFO_WEN_DEFAULT (15UL << USB_EP4_FIFO_WR_EN_Pos)
330 #define LL_USB_EP4_FIFO_WEN_1BYTE (1UL << USB_EP4_FIFO_WR_EN_Pos)
331 #define LL_USB_EP4_FIFO_WEN_2BYTE (3UL << USB_EP4_FIFO_WR_EN_Pos)
332 #define LL_USB_EP4_FIFO_WEN_3BYTE (7UL << USB_EP4_FIFO_WR_EN_Pos)
333 #define LL_USB_EP4_FIFO_WEN_4BYTE (15UL << USB_EP4_FIFO_WR_EN_Pos)
354 #define LL_USB_WriteReg(__instance__, __REG__, __VALUE__) WRITE_REG(__instance__->__REG__, (__VALUE__))
362 #define LL_USB_ReadReg(__instance__, __REG__) READ_REG(__instance__->__REG__)
390 __STATIC_INLINE
void ll_usb_enable_xcvr_ldo33_lp(aon_pmu_regs_t *AON_PMUx)
392 SET_BITS(AON_PMUx->USB_TRX_LDO, AON_PMU_USB_TRX_LDO_LP_EN);
405 __STATIC_INLINE
void ll_usb_disable_xcvr_ldo33_lp(aon_pmu_regs_t *AON_PMUx)
407 CLEAR_BITS(AON_PMUx->USB_TRX_LDO, AON_PMU_USB_TRX_LDO_LP_EN);
420 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_ldo33_lp(aon_pmu_regs_t *AON_PMUx)
422 return (READ_BITS(AON_PMUx->USB_TRX_LDO, AON_PMU_USB_TRX_LDO_LP_EN) == (AON_PMU_USB_TRX_LDO_LP_EN));
435 __STATIC_INLINE
void ll_usb_enable_xcvr_ldo33_vref_test(mcu_sub_regs_t *MCU_SUBx)
437 SET_BITS(MCU_SUBx->USB_XCRV_LDO, MCU_SUB_USB_XCRV_LDO_VREF_TEST_EN);
450 __STATIC_INLINE
void ll_usb_disable_xcvr_ldo33_vref_test(mcu_sub_regs_t *MCU_SUBx)
452 CLEAR_BITS(MCU_SUBx->USB_XCRV_LDO, MCU_SUB_USB_XCRV_LDO_VREF_TEST_EN);
465 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_ldo33_vref_test(mcu_sub_regs_t *MCU_SUBx)
467 return (READ_BITS(MCU_SUBx->USB_XCRV_LDO, MCU_SUB_USB_XCRV_LDO_VREF_TEST_EN) == (MCU_SUB_USB_XCRV_LDO_VREF_TEST_EN));
489 __STATIC_INLINE
void ll_usb_set_xcrv_ldo33_bias(aon_pmu_regs_t *AON_PMUx, uint32_t value)
491 MODIFY_REG(AON_PMUx->USB_TRX_LDO, AON_PMU_USB_TRX_LDO_BIAS_SEL, value);
512 __STATIC_INLINE uint32_t ll_usb_get_xcrv_ldo33_bias(aon_pmu_regs_t *AON_PMUx)
514 return (uint32_t)(READ_BITS(AON_PMUx->USB_TRX_LDO, AON_PMU_USB_TRX_LDO_BIAS_SEL));
536 __STATIC_INLINE
void ll_usb_set_xcrv_ldo33_VSEL(aon_pmu_regs_t *AON_PMUx, uint32_t value)
538 MODIFY_REG(AON_PMUx->USB_TRX_LDO, AON_PMU_USB_TRX_LDO_BIAS_SEL, value);
559 __STATIC_INLINE uint32_t ll_usb_get_xcrv_ldo33_VSEL(aon_pmu_regs_t *AON_PMUx)
561 return (uint32_t)(READ_BITS(AON_PMUx->USB_TRX_LDO, AON_PMU_USB_TRX_LDO_BIAS_SEL));
575 __STATIC_INLINE
void ll_usb_enable_suspend_clk_off(mcu_sub_regs_t *MCU_SUBx)
577 SET_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_SUSPEND_CLK_OFF);
590 __STATIC_INLINE
void ll_usb_disable_suspend_clk_off(mcu_sub_regs_t *MCU_SUBx)
592 CLEAR_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_SUSPEND_CLK_OFF);
605 __STATIC_INLINE uint32_t ll_usb_is_enabled_suspend_clk_off(mcu_sub_regs_t *MCU_SUBx)
607 return (READ_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_SUSPEND_CLK_OFF) == (MCU_SUB_USB_LP_CTRL_SUSPEND_CLK_OFF));
620 __STATIC_INLINE
void ll_usb_enable_pmu_lp(mcu_sub_regs_t *MCU_SUBx)
622 SET_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_PMU_LP_EN);
635 __STATIC_INLINE
void ll_usb_disable_pmu_lp(mcu_sub_regs_t *MCU_SUBx)
637 CLEAR_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_PMU_LP_EN);
650 __STATIC_INLINE uint32_t ll_usb_is_enabled_pmu_lp(mcu_sub_regs_t *MCU_SUBx)
652 return (READ_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_PMU_LP_EN) == (MCU_SUB_USB_LP_CTRL_PMU_LP_EN));
666 __STATIC_INLINE
void ll_usb_enable_clk_force_off(mcu_sub_regs_t *MCU_SUBx)
668 SET_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_CLK_FORCE_OFF);
681 __STATIC_INLINE
void ll_usb_disable_clk_force_off(mcu_sub_regs_t *MCU_SUBx)
683 CLEAR_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_CLK_FORCE_OFF);
696 __STATIC_INLINE uint32_t ll_usb_enabled_clk_force_off_is(mcu_sub_regs_t *MCU_SUBx)
698 return (READ_BITS(MCU_SUBx->USB_LP_CTRL, MCU_SUB_USB_LP_CTRL_CLK_FORCE_OFF) == (MCU_SUB_USB_LP_CTRL_CLK_FORCE_OFF));
711 __STATIC_INLINE
void ll_usb_enable_xcvr_secmp_pd(mcu_sub_regs_t *MCU_SUBx)
713 SET_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_SECMP_PD);
726 __STATIC_INLINE
void ll_usb_disable_xcvr_secmp_pd(mcu_sub_regs_t *MCU_SUBx)
728 CLEAR_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_SECMP_PD);
741 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_secmp_pd(mcu_sub_regs_t *MCU_SUBx)
743 return (READ_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_SECMP_PD) == (MCU_SUB_USB_XCRV_CTRL_SECMP_PD));
759 __STATIC_INLINE
void ll_usb_set_xcrv_speed(mcu_sub_regs_t *MCU_SUBx, uint32_t speed)
761 MODIFY_REG(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_SPEED, speed);
776 __STATIC_INLINE uint32_t ll_usb_get_xcrv_speed(mcu_sub_regs_t *MCU_SUBx)
778 return (uint32_t)(READ_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_SPEED));
791 __STATIC_INLINE
void ll_usb_enable_xcvr_suspend(mcu_sub_regs_t *MCU_SUBx)
793 SET_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_SUSPEND);
806 __STATIC_INLINE
void ll_usb_disable_xcvr_suspend(mcu_sub_regs_t *MCU_SUBx)
808 CLEAR_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_SUSPEND);
821 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_suspend(mcu_sub_regs_t *MCU_SUBx)
823 return (READ_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_SUSPEND) == (MCU_SUB_USB_XCRV_CTRL_SUSPEND));
836 __STATIC_INLINE
void ll_usb_enable_xcvr_bias(mcu_sub_regs_t *MCU_SUBx)
838 SET_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_BIAS_EN);
851 __STATIC_INLINE
void ll_usb_disable_xcvr_bias(mcu_sub_regs_t *MCU_SUBx)
853 CLEAR_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_BIAS_EN);
866 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_bias(mcu_sub_regs_t *MCU_SUBx)
868 return (READ_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_BIAS_EN) == (MCU_SUB_USB_XCRV_CTRL_BIAS_EN));
890 __STATIC_INLINE
void ll_usb_set_xcrv_rtrimn(mcu_sub_regs_t *MCU_SUBx, uint32_t value)
892 MODIFY_REG(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_RTRIMN, value);
913 __STATIC_INLINE uint32_t ll_usb_get_xcrv_rtrimn(mcu_sub_regs_t *MCU_SUBx)
915 return (uint32_t)(READ_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_RTRIMN));
937 __STATIC_INLINE
void ll_usb_set_xcrv_rtrimp(mcu_sub_regs_t *MCU_SUBx, uint32_t value)
939 MODIFY_REG(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_RTRIMP, value);
960 __STATIC_INLINE uint32_t ll_usb_get_xcrv_rtrimp(mcu_sub_regs_t *MCU_SUBx)
962 return (uint32_t)(READ_BITS(MCU_SUBx->USB_XCRV_CTRL, MCU_SUB_USB_XCRV_CTRL_RTRIMP));
975 __STATIC_INLINE
void ll_usb_enable_sw_reset(mcu_sub_regs_t *MCU_SUBx)
977 SET_BITS(MCU_SUBx->USB_SW_RST, MCU_SUB_USB_SW_RST_EN);
990 __STATIC_INLINE
void ll_usb_disable_sw_reset(mcu_sub_regs_t *MCU_SUBx)
992 CLEAR_BITS(MCU_SUBx->USB_SW_RST, MCU_SUB_USB_SW_RST_EN);
1005 __STATIC_INLINE uint32_t ll_usb_is_enabled_sw_reset(mcu_sub_regs_t *MCU_SUBx)
1007 return (READ_BITS(MCU_SUBx->USB_SW_RST, MCU_SUB_USB_SW_RST_EN) == (MCU_SUB_USB_SW_RST_EN));
1023 __STATIC_INLINE
void ll_usb_set_usb_enum_type(usb_regs_t *USBx, uint32_t type)
1025 MODIFY_REG(USBx->CTRL, USB_CTRL_MCU_ENUM, type);
1040 __STATIC_INLINE uint32_t ll_usb_get_enum_type(usb_regs_t *USBx)
1042 return (uint32_t)(READ_BITS(USBx->CTRL, USB_CTRL_MCU_ENUM));
1055 __STATIC_INLINE
void ll_usb_enable_ep0_out_dat_rdy(usb_regs_t *USBx)
1057 SET_BITS(USBx->CTRL, USB_CTRL_EP0_OUT_DATA_RDY);
1070 __STATIC_INLINE
void ll_usb_disable_ep0_out_dat_rdy(usb_regs_t *USBx)
1072 CLEAR_BITS(USBx->CTRL, USB_CTRL_EP0_OUT_DATA_RDY);
1085 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep0_out_dat_rdy(usb_regs_t *USBx)
1087 return (READ_BITS(USBx->CTRL, USB_CTRL_EP0_OUT_DATA_RDY) == (USB_CTRL_EP0_OUT_DATA_RDY));
1100 __STATIC_INLINE
void ll_usb_enable_mcu_wakeup(usb_regs_t *USBx)
1102 SET_BITS(USBx->CTRL, USB_CTRL_MCU_WAKEUP);
1115 __STATIC_INLINE
void ll_usb_disable_mcu_wakeup(usb_regs_t *USBx)
1117 CLEAR_BITS(USBx->CTRL, USB_CTRL_MCU_WAKEUP);
1131 __STATIC_INLINE
void ll_usb_enable_dev_remote_wakeup(usb_regs_t *USBx)
1133 SET_BITS(USBx->CTRL, USB_CTRL_DEV_REMOTE_WAKEUP);
1146 __STATIC_INLINE
void ll_usb_disable_dev_remote_wakeup(usb_regs_t *USBx)
1148 CLEAR_BITS(USBx->CTRL, USB_CTRL_DEV_REMOTE_WAKEUP);
1161 __STATIC_INLINE uint32_t ll_usb_is_enabled_dev_remote_wakeup(usb_regs_t *USBx)
1163 return (READ_BITS(USBx->CTRL, USB_CTRL_DEV_REMOTE_WAKEUP) == (USB_CTRL_DEV_REMOTE_WAKEUP));
1176 __STATIC_INLINE
void ll_usb_enable_addr_stat(usb_regs_t *USBx)
1178 SET_BITS(USBx->CTRL, USB_CTRL_ADDR_STAT);
1191 __STATIC_INLINE
void ll_usb_disable_addr_stat(usb_regs_t *USBx)
1193 CLEAR_BITS(USBx->CTRL, USB_CTRL_ADDR_STAT);
1206 __STATIC_INLINE uint32_t ll_usb_is_enabled_addr_stat(usb_regs_t *USBx)
1208 return (READ_BITS(USBx->CTRL, USB_CTRL_ADDR_STAT) == (USB_CTRL_ADDR_STAT));
1221 __STATIC_INLINE
void ll_usb_enable_cfg_stat(usb_regs_t *USBx)
1223 SET_BITS(USBx->CTRL, USB_CTRL_CFG_STAT);
1236 __STATIC_INLINE
void ll_usb_disable_cfg_stat(usb_regs_t *USBx)
1238 CLEAR_BITS(USBx->CTRL, USB_CTRL_CFG_STAT);
1251 __STATIC_INLINE uint32_t ll_usb_is_enabled_cfg_stat(usb_regs_t *USBx)
1253 return (READ_BITS(USBx->CTRL, USB_CTRL_CFG_STAT) == (USB_CTRL_CFG_STAT));
1266 __STATIC_INLINE
void ll_usb_enable_cmd_ok(usb_regs_t *USBx)
1268 SET_BITS(USBx->CTRL, USB_CTRL_CMD_OK);
1281 __STATIC_INLINE
void ll_usb_disable_cmd_ok(usb_regs_t *USBx)
1283 CLEAR_BITS(USBx->CTRL, USB_CTRL_CMD_OK);
1296 __STATIC_INLINE
void ll_usb_enable_cmd_err(usb_regs_t *USBx)
1298 SET_BITS(USBx->CTRL, USB_CTRL_CMD_ERR);
1311 __STATIC_INLINE
void ll_usb_disable_cmd_err(usb_regs_t *USBx)
1313 CLEAR_BITS(USBx->CTRL, USB_CTRL_CMD_ERR);
1328 __STATIC_INLINE
void ll_usb_set_func_addr(usb_regs_t *USBx, uint32_t addr)
1330 MODIFY_REG(USBx->CTRL, USB_CTRL_FUNC_ADDR, addr << USB_CTRL_FUNC_ADDR_Pos);
1344 __STATIC_INLINE uint32_t ll_usb_get_func_addr(usb_regs_t *USBx)
1346 return (uint32_t)(READ_BITS(USBx->CTRL, USB_CTRL_FUNC_ADDR) >> USB_CTRL_FUNC_ADDR_Pos);
1359 __STATIC_INLINE
void ll_usb_enable_ep1_out_dat_rdy(usb_regs_t *USBx)
1361 SET_BITS(USBx->CTRL, USB_CTRL_EP1_OUT_DATA_RDY);
1374 __STATIC_INLINE
void ll_usb_disable_ep1_out_dat_rdy(usb_regs_t *USBx)
1376 CLEAR_BITS(USBx->CTRL, USB_CTRL_EP1_OUT_DATA_RDY);
1389 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep1_out_dat_rdy(usb_regs_t *USBx)
1391 return (READ_BITS(USBx->CTRL, USB_CTRL_EP1_OUT_DATA_RDY) == (USB_CTRL_EP1_OUT_DATA_RDY));
1404 __STATIC_INLINE
void ll_usb_enable_ep5_out_dat_rdy(usb_regs_t *USBx)
1406 SET_BITS(USBx->CTRL, USB_CTRL_EP5_OUT_DATA_RDY);
1419 __STATIC_INLINE
void ll_usb_disable_ep5_out_dat_rdy(usb_regs_t *USBx)
1421 CLEAR_BITS(USBx->CTRL, USB_CTRL_EP5_OUT_DATA_RDY);
1434 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep5_out_dat_rdy(usb_regs_t *USBx)
1436 return (READ_BITS(USBx->CTRL, USB_CTRL_EP5_OUT_DATA_RDY) == (USB_CTRL_EP5_OUT_DATA_RDY));
1449 __STATIC_INLINE
void ll_usb_enable_ep0_fifo_switch(usb_regs_t *USBx)
1451 SET_BITS(USBx->CTRL, USB_CTRL_EP0_FIFO_SWITCH);
1464 __STATIC_INLINE
void ll_usb_disable_ep0_fifo_switch(usb_regs_t *USBx)
1466 CLEAR_BITS(USBx->CTRL, USB_CTRL_EP0_FIFO_SWITCH);
1479 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep0_fifo_switch(usb_regs_t *USBx)
1481 return (READ_BITS(USBx->CTRL, USB_CTRL_EP0_FIFO_SWITCH) == (USB_CTRL_EP0_FIFO_SWITCH));
1495 __STATIC_INLINE
void ll_usb_enable_ep0_dat_rdy(usb_regs_t *USBx)
1497 SET_BITS(USBx->EP0_1_CTRL, USB_EP0_CTRL_DATA_RDY);
1510 __STATIC_INLINE
void ll_usb_disable_ep0_dat_rdy(usb_regs_t *USBx)
1512 CLEAR_BITS(USBx->EP0_1_CTRL, USB_EP0_CTRL_DATA_RDY);
1525 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep0_dat_rdy(usb_regs_t *USBx)
1527 return (READ_BITS(USBx->EP0_1_CTRL, USB_EP0_CTRL_DATA_RDY) == (USB_EP0_CTRL_DATA_RDY));
1540 __STATIC_INLINE
void ll_usb_enable_clr_ep0_fifo(usb_regs_t *USBx)
1542 SET_BITS(USBx->EP0_1_CTRL, USB_EP0_CTRL_IFIFO_CLR);
1555 __STATIC_INLINE
void ll_usb_disable_clr_ep0_fifo(usb_regs_t *USBx)
1557 CLEAR_BITS(USBx->EP0_1_CTRL, USB_EP0_CTRL_IFIFO_CLR);
1570 __STATIC_INLINE
void ll_usb_enable_clr_ep1_fifo(usb_regs_t *USBx)
1572 SET_BITS(USBx->EP0_1_CTRL, USB_EP1_CTRL_IFIFO_CLR);
1585 __STATIC_INLINE
void ll_usb_disable_clr_ep1_fifo(usb_regs_t *USBx)
1587 CLEAR_BITS(USBx->EP0_1_CTRL, USB_EP1_CTRL_IFIFO_CLR);
1600 __STATIC_INLINE
void ll_usb_enable_ep2_dat_rdy(usb_regs_t *USBx)
1602 SET_BITS(USBx->EP2_CTRL, USB_EP2_CTRL_DATA_RDY);
1615 __STATIC_INLINE
void ll_usb_disable_ep2_dat_rdy(usb_regs_t *USBx)
1617 CLEAR_BITS(USBx->EP2_CTRL, USB_EP2_CTRL_DATA_RDY);
1630 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep2_dat_rdy(usb_regs_t *USBx)
1632 return (READ_BITS(USBx->EP2_CTRL, USB_EP2_CTRL_DATA_RDY) == (USB_EP2_CTRL_DATA_RDY));
1645 __STATIC_INLINE
void ll_usb_enable_clr_ep2_fifo(usb_regs_t *USBx)
1647 SET_BITS(USBx->EP2_CTRL, USB_EP2_CTRL_IFIFO_CLR);
1660 __STATIC_INLINE
void ll_usb_disable_clr_ep2_fifo(usb_regs_t *USBx)
1662 CLEAR_BITS(USBx->EP2_CTRL, USB_EP2_CTRL_IFIFO_CLR);
1675 __STATIC_INLINE
void ll_usb_enable_ep3_dat_rdy(usb_regs_t *USBx)
1677 SET_BITS(USBx->EP3_CTRL, USB_EP3_CTRL_DATA_RDY);
1690 __STATIC_INLINE
void ll_usb_disable_ep3_dat_rdy(usb_regs_t *USBx)
1692 CLEAR_BITS(USBx->EP3_CTRL, USB_EP3_CTRL_DATA_RDY);
1705 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep3_dat_rdy(usb_regs_t *USBx)
1707 return (READ_BITS(USBx->EP3_CTRL, USB_EP3_CTRL_DATA_RDY) == (USB_EP3_CTRL_DATA_RDY));
1720 __STATIC_INLINE
void ll_usb_enable_clr_ep3_fifo(usb_regs_t *USBx)
1722 SET_BITS(USBx->EP3_CTRL, USB_EP3_CTRL_IFIFO_CLR);
1735 __STATIC_INLINE
void ll_usb_disable_clr_ep3_fifo(usb_regs_t *USBx)
1737 CLEAR_BITS(USBx->EP3_CTRL, USB_EP3_CTRL_IFIFO_CLR);
1750 __STATIC_INLINE
void ll_usb_enable_ep4_dat_rdy(usb_regs_t *USBx)
1752 SET_BITS(USBx->EP4_CTRL, USB_EP4_CTRL_DATA_RDY);
1765 __STATIC_INLINE
void ll_usb_disable_ep4_dat_rdy(usb_regs_t *USBx)
1767 CLEAR_BITS(USBx->EP4_CTRL, USB_EP4_CTRL_DATA_RDY);
1780 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep4_dat_rdy(usb_regs_t *USBx)
1782 return (READ_BITS(USBx->EP4_CTRL, USB_EP4_CTRL_DATA_RDY) == (USB_EP4_CTRL_DATA_RDY));
1795 __STATIC_INLINE
void ll_usb_enable_clr_ep4_fifo(usb_regs_t *USBx)
1797 SET_BITS(USBx->EP4_CTRL, USB_EP4_CTRL_IFIFO_CLR);
1810 __STATIC_INLINE
void ll_usb_disable_clr_ep4_fifo(usb_regs_t *USBx)
1812 CLEAR_BITS(USBx->EP4_CTRL, USB_EP4_CTRL_IFIFO_CLR);
1825 __STATIC_INLINE
void ll_usb_enable_ep4_empty_packet(usb_regs_t *USBx)
1827 SET_BITS(USBx->EP4_CTRL, USB_EP4_CTRL_EMPTY_PACKET_EN);
1840 __STATIC_INLINE
void ll_usb_disable_ep4_empty_packet(usb_regs_t *USBx)
1842 CLEAR_BITS(USBx->EP4_CTRL, USB_EP4_CTRL_EMPTY_PACKET_EN);
1855 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep4_empty_packet(usb_regs_t *USBx)
1857 return (READ_BITS(USBx->EP4_CTRL, USB_EP4_CTRL_EMPTY_PACKET_EN) == (USB_EP4_CTRL_EMPTY_PACKET_EN));
1870 __STATIC_INLINE
void ll_usb_enable_clr_ep5_fifo(usb_regs_t *USBx)
1872 SET_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_FIFO_CLR);
1885 __STATIC_INLINE
void ll_usb_disable_clr_ep5_fifo(usb_regs_t *USBx)
1887 CLEAR_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_FIFO_CLR);
1903 __STATIC_INLINE
void ll_usb_set_ep1_attr(usb_regs_t *USBx, uint32_t attr)
1905 MODIFY_REG(USBx->EP_ATTR, USB_EP_ATTR_EP1, attr);
1921 __STATIC_INLINE uint32_t ll_usb_get_ep1_attr(usb_regs_t *USBx)
1923 return (uint32_t)(READ_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP1));
1940 __STATIC_INLINE
void ll_usb_set_ep2_attr(usb_regs_t *USBx, uint32_t attr)
1942 MODIFY_REG(USBx->EP_ATTR, USB_EP_ATTR_EP2, attr);
1958 __STATIC_INLINE uint32_t ll_usb_get_ep2_attr(usb_regs_t *USBx)
1960 return (uint32_t)(READ_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP2));
1977 __STATIC_INLINE
void ll_usb_set_ep3_attr(usb_regs_t *USBx, uint32_t attr)
1979 MODIFY_REG(USBx->EP_ATTR, USB_EP_ATTR_EP3, attr);
1995 __STATIC_INLINE uint32_t ll_usb_get_ep3_attr(usb_regs_t *USBx)
1997 return (uint32_t)(READ_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP3));
2010 __STATIC_INLINE
void ll_usb_enable_ep1_halt_mcu(usb_regs_t *USBx)
2012 SET_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP1_HALT_MCU);
2025 __STATIC_INLINE
void ll_usb_disable_ep1_halt_mcu(usb_regs_t *USBx)
2027 CLEAR_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP1_HALT_MCU);
2040 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep1_halt_mcu(usb_regs_t *USBx)
2042 return (READ_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP1_HALT_MCU) == (USB_EP_ATTR_EP1_HALT_MCU));
2055 __STATIC_INLINE
void ll_usb_enable_ep2_halt_mcu(usb_regs_t *USBx)
2057 SET_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP2_HALT_MCU);
2070 __STATIC_INLINE
void ll_usb_disable_ep2_halt_mcu(usb_regs_t *USBx)
2072 CLEAR_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP2_HALT_MCU);
2085 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep2_halt_mcu(usb_regs_t *USBx)
2087 return (READ_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP2_HALT_MCU) == (USB_EP_ATTR_EP2_HALT_MCU));
2100 __STATIC_INLINE
void ll_usb_enable_ep3_halt_mcu(usb_regs_t *USBx)
2102 SET_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP3_HALT_MCU);
2115 __STATIC_INLINE
void ll_usb_disable_ep3_halt_mcu(usb_regs_t *USBx)
2117 CLEAR_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP3_HALT_MCU);
2130 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep3_halt_mcu(usb_regs_t *USBx)
2132 return (READ_BITS(USBx->EP_ATTR, USB_EP_ATTR_EP3_HALT_MCU) == (USB_EP_ATTR_EP3_HALT_MCU));
2197 __STATIC_INLINE uint32_t ll_usb_is_active_it_flag(usb_regs_t *USBx, uint32_t flag)
2199 return (uint32_t)(READ_BITS(USBx->INT_STAT, flag) == flag);
2237 __STATIC_INLINE uint32_t ll_usb_get_it_flag(usb_regs_t *USBx)
2239 return (uint32_t)(READ_BITS(USBx->INT_STAT, LL_USB_INT_STAT_ALL));
2306 __STATIC_INLINE
void ll_usb_enable_it(usb_regs_t *USBx, uint32_t mask)
2308 SET_BITS(USBx->INT_EN, mask);
2375 __STATIC_INLINE
void ll_usb_disable_it(usb_regs_t *USBx, uint32_t mask)
2377 CLEAR_BITS(USBx->INT_EN, mask);
2444 __STATIC_INLINE uint32_t ll_usb_is_enabled_it(usb_regs_t *USBx, uint32_t mask)
2446 return (READ_BITS(USBx->INT_EN, mask) == (mask));
2512 __STATIC_INLINE
void ll_usb_clear_it(usb_regs_t *USBx, uint32_t mask)
2514 SET_BITS(USBx->INT_CLR, mask);
2529 __STATIC_INLINE
void ll_usb_set_ep3_ahb_m_rd_start_addr(usb_regs_t *USBx, uint32_t addr)
2531 MODIFY_REG(USBx->EP3_AHBM_RADDR, USB_EP3_AHBM_RADDR_RD_START_ADDR, addr);
2545 __STATIC_INLINE uint32_t ll_usb_get_ep3_ahb_m_rd_start_addr(usb_regs_t *USBx)
2547 return (uint32_t)(READ_BITS(USBx->EP3_AHBM_RADDR, USB_EP3_AHBM_RADDR_RD_START_ADDR));
2560 __STATIC_INLINE
void ll_usb_enable_ep3_ahb_m(usb_regs_t *USBx)
2562 SET_BITS(USBx->EP3_AHBM_CTRL, USB_EP3_AHBM_CTRL_EN);
2575 __STATIC_INLINE
void ll_usb_disable_ep3_ahb_m(usb_regs_t *USBx)
2577 CLEAR_BITS(USBx->EP3_AHBM_CTRL, USB_EP3_AHBM_CTRL_EN);
2590 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep3_ahb_m(usb_regs_t *USBx)
2592 return (READ_BITS(USBx->EP3_AHBM_CTRL, USB_EP3_AHBM_CTRL_EN) == (USB_EP3_AHBM_CTRL_EN));
2607 __STATIC_INLINE
void ll_usb_set_ep3_ahb_m_burst_size(usb_regs_t *USBx, uint32_t size)
2609 MODIFY_REG(USBx->EP3_AHBM_CTRL, USB_EP3_AHBM_CTRL_BURST_SIZE, size << USB_EP3_AHBM_CTRL_BURST_SIZE_Pos);
2623 __STATIC_INLINE uint32_t ll_usb_get_ep3_ahb_m_burst_size(usb_regs_t *USBx)
2625 return (uint32_t)(READ_BITS(USBx->EP3_AHBM_CTRL, USB_EP3_AHBM_CTRL_BURST_SIZE) >> USB_EP3_AHBM_CTRL_BURST_SIZE_Pos);
2640 __STATIC_INLINE
void ll_usb_set_ep4_ahb_m_rd_start_addr(usb_regs_t *USBx, uint32_t addr)
2642 MODIFY_REG(USBx->EP4_AHBM_RADDR, USB_EP4_AHBM_RADDR_RD_START_ADDR, addr);
2656 __STATIC_INLINE uint32_t ll_usb_get_ep4_ahb_m_rd_start_addr(usb_regs_t *USBx)
2658 return (uint32_t)(READ_BITS(USBx->EP4_AHBM_RADDR, USB_EP4_AHBM_RADDR_RD_START_ADDR));
2671 __STATIC_INLINE
void ll_usb_enable_ep4_ahb_m(usb_regs_t *USBx)
2673 SET_BITS(USBx->EP4_AHBM_CTRL, USB_EP4_AHBM_CTRL_EN);
2686 __STATIC_INLINE
void ll_usb_disable_ep4_ahb_m(usb_regs_t *USBx)
2688 CLEAR_BITS(USBx->EP4_AHBM_CTRL, USB_EP4_AHBM_CTRL_EN);
2701 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep4_ahb_m(usb_regs_t *USBx)
2703 return (READ_BITS(USBx->EP4_AHBM_CTRL, USB_EP4_AHBM_CTRL_EN) == (USB_EP4_AHBM_CTRL_EN));
2718 __STATIC_INLINE
void ll_usb_set_ep4_ahb_m_burst_size(usb_regs_t *USBx, uint32_t size)
2720 MODIFY_REG(USBx->EP4_AHBM_CTRL, USB_EP4_AHBM_CTRL_BURST_SIZE, size << USB_EP4_AHBM_CTRL_BURST_SIZE_Pos);
2734 __STATIC_INLINE uint32_t ll_usb_get_ep4_ahb_m_burst_size(usb_regs_t *USBx)
2736 return (uint32_t)(READ_BITS(USBx->EP4_AHBM_CTRL, USB_EP4_AHBM_CTRL_BURST_SIZE) >> USB_EP4_AHBM_CTRL_BURST_SIZE_Pos);
2751 __STATIC_INLINE
void ll_usb_set_ep5_ahb_m_rd_start_addr(usb_regs_t *USBx, uint32_t addr)
2753 MODIFY_REG(USBx->EP5_AHBM_RADDR, USB_EP5_AHBM_RADDR_RD_START_ADDR, addr);
2767 __STATIC_INLINE uint32_t ll_usb_get_ep5_ahb_m_rd_start_addr(usb_regs_t *USBx)
2769 return (uint32_t)(READ_BITS(USBx->EP5_AHBM_RADDR, USB_EP5_AHBM_RADDR_RD_START_ADDR));
2782 __STATIC_INLINE
void ll_usb_enable_ep5_ahb_m(usb_regs_t *USBx)
2784 SET_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_AHBM_EN);
2797 __STATIC_INLINE
void ll_usb_disable_ep5_ahb_m(usb_regs_t *USBx)
2799 CLEAR_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_AHBM_EN);
2812 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep5_ahb_m(usb_regs_t *USBx)
2814 return (READ_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_AHBM_EN) == (USB_EP5_CTRL_AHBM_EN));
2827 __STATIC_INLINE
void ll_usb_enable_ep5_fifo_clr(usb_regs_t *USBx)
2829 SET_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_FIFO_CLR);
2842 __STATIC_INLINE
void ll_usb_disable_ep5_fifo_clr(usb_regs_t *USBx)
2844 CLEAR_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_FIFO_CLR);
2857 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep5_fifo_clr(usb_regs_t *USBx)
2859 return (READ_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_FIFO_CLR) == (USB_EP5_CTRL_FIFO_CLR));
2872 __STATIC_INLINE
void ll_usb_enable_ep5_rx_cnt_no_overwrite(usb_regs_t *USBx)
2874 SET_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_RX_CNT_NO_OVERWRITE);
2887 __STATIC_INLINE
void ll_usb_disable_ep5_rx_cnt_no_overwrite(usb_regs_t *USBx)
2889 CLEAR_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_RX_CNT_NO_OVERWRITE);
2902 __STATIC_INLINE uint32_t ll_usb_is_enabled_ep5_rx_cnt_no_overwrite(usb_regs_t *USBx)
2904 return (READ_BITS(USBx->EP5_CTRL, USB_EP5_CTRL_RX_CNT_NO_OVERWRITE) == (USB_EP5_CTRL_RX_CNT_NO_OVERWRITE));
2917 __STATIC_INLINE
void ll_usb_enable_test_mode(usb_regs_t *USBx)
2919 SET_BITS(USBx->CTRL0, USB_CTRL0_TEST_MODE);
2932 __STATIC_INLINE
void ll_usb_disable_test_mode(usb_regs_t *USBx)
2934 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_TEST_MODE);
2947 __STATIC_INLINE uint32_t ll_usb_is_enabled_test_mode(usb_regs_t *USBx)
2949 return (READ_BITS(USBx->CTRL0, USB_CTRL0_TEST_MODE) == (USB_CTRL0_TEST_MODE));
2962 __STATIC_INLINE
void ll_usb_enable_drive_dp(usb_regs_t *USBx)
2964 SET_BITS(USBx->CTRL0, USB_CTRL0_DRIVE_DP);
2977 __STATIC_INLINE
void ll_usb_disable_drive_dp(usb_regs_t *USBx)
2979 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_DRIVE_DP);
2992 __STATIC_INLINE uint32_t ll_usb_is_enabled_drive_dp(usb_regs_t *USBx)
2994 return (READ_BITS(USBx->CTRL0, USB_CTRL0_DRIVE_DP) == (USB_CTRL0_DRIVE_DP));
3007 __STATIC_INLINE
void ll_usb_enable_drive_dm(usb_regs_t *USBx)
3009 SET_BITS(USBx->CTRL0, USB_CTRL0_DRIVE_DM);
3022 __STATIC_INLINE
void ll_usb_disable_drive_dm(usb_regs_t *USBx)
3024 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_DRIVE_DM);
3037 __STATIC_INLINE uint32_t ll_usb_is_enabled_drive_dm(usb_regs_t *USBx)
3039 return (READ_BITS(USBx->CTRL0, USB_CTRL0_DRIVE_DM) == (USB_CTRL0_DRIVE_DM));
3052 __STATIC_INLINE
void ll_usb_enable_xcvr_oeb(usb_regs_t *USBx)
3054 SET_BITS(USBx->CTRL0, USB_CTRL0_XCVR_OEB);
3067 __STATIC_INLINE
void ll_usb_disable_xcvr_oeb(usb_regs_t *USBx)
3069 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_XCVR_OEB);
3082 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_oeb(usb_regs_t *USBx)
3084 return (READ_BITS(USBx->CTRL0, USB_CTRL0_XCVR_OEB) == (USB_CTRL0_XCVR_OEB));
3097 __STATIC_INLINE
void ll_usb_enable_xcvr_dp_rpu(usb_regs_t *USBx)
3099 SET_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPU_EN);
3112 __STATIC_INLINE
void ll_usb_disable_xcvr_dp_rpu(usb_regs_t *USBx)
3114 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPU_EN);
3127 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_dp_rpu(usb_regs_t *USBx)
3129 return (READ_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPU_EN) == (USB_CTRL0_XCVR_DP_RPU_EN));
3142 __STATIC_INLINE
void ll_usb_enable_xcvr_dm_rpu(usb_regs_t *USBx)
3144 SET_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPU_EN);
3157 __STATIC_INLINE
void ll_usb_disable_xcvr_dm_rpu(usb_regs_t *USBx)
3159 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPU_EN);
3172 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_dm_rpu(usb_regs_t *USBx)
3174 return (READ_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPU_EN) == (USB_CTRL0_XCVR_DM_RPU_EN));
3187 __STATIC_INLINE
void ll_usb_enable_xcvr_dp_rpusw(usb_regs_t *USBx)
3189 SET_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPUSW_EN);
3202 __STATIC_INLINE
void ll_usb_disable_xcvr_dp_rpusw(usb_regs_t *USBx)
3204 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPUSW_EN);
3217 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_dp_rpusw(usb_regs_t *USBx)
3219 return (READ_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPUSW_EN) == (USB_CTRL0_XCVR_DP_RPUSW_EN));
3232 __STATIC_INLINE
void ll_usb_enable_xcvr_dm_rpusw(usb_regs_t *USBx)
3234 SET_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPUSW_EN);
3247 __STATIC_INLINE
void ll_usb_disable_xcvr_dm_rpusw(usb_regs_t *USBx)
3249 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPUSW_EN);
3262 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_dm_rpusw(usb_regs_t *USBx)
3264 return (READ_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPUSW_EN) == (USB_CTRL0_XCVR_DM_RPUSW_EN));
3277 __STATIC_INLINE
void ll_usb_enable_xcvr_dp_rpd(usb_regs_t *USBx)
3279 SET_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPD_EN);
3292 __STATIC_INLINE
void ll_usb_disable_xcvr_dp_rpd(usb_regs_t *USBx)
3294 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPD_EN);
3307 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_dp_rpd(usb_regs_t *USBx)
3309 return (READ_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DP_RPD_EN) == (USB_CTRL0_XCVR_DP_RPD_EN));
3322 __STATIC_INLINE
void ll_usb_enable_xcvr_dm_rpd(usb_regs_t *USBx)
3324 SET_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPD_EN);
3337 __STATIC_INLINE
void ll_usb_disable_xcvr_dm_rpd(usb_regs_t *USBx)
3339 CLEAR_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPD_EN);
3352 __STATIC_INLINE uint32_t ll_usb_is_enabled_xcvr_dm_rpd(usb_regs_t *USBx)
3354 return (READ_BITS(USBx->CTRL0, USB_CTRL0_XCVR_DM_RPD_EN) == (USB_CTRL0_XCVR_DM_RPD_EN));
3370 __STATIC_INLINE
void ll_usb_set_output_endian_mode(usb_regs_t *USBx, uint32_t mode)
3372 MODIFY_REG(USBx->CTRL0, USB_CTRL0_OUTPUT_ENDIAN_CTRL, mode);
3387 __STATIC_INLINE uint32_t ll_usb_get_output_endian_mode(usb_regs_t *USBx)
3389 return (uint32_t)(READ_BITS(USBx->CTRL0, USB_CTRL0_OUTPUT_ENDIAN_CTRL));
3405 __STATIC_INLINE
void ll_usb_set_input_endian_mode(usb_regs_t *USBx, uint32_t mode)
3407 MODIFY_REG(USBx->CTRL0, USB_CTRL0_INPUT_ENDIAN_CTRL, mode);
3422 __STATIC_INLINE uint32_t ll_usb_get_input_endian_mode(usb_regs_t *USBx)
3424 return (uint32_t)(READ_BITS(USBx->CTRL0, USB_CTRL0_INPUT_ENDIAN_CTRL));
3444 __STATIC_INLINE
void ll_usb_set_probe_sel(usb_regs_t *USBx, uint32_t sel)
3446 MODIFY_REG(USBx->CTRL0, USB_CTRL0_PROBE_SEL, sel);
3465 __STATIC_INLINE uint32_t ll_usb_get_probe_sel(usb_regs_t *USBx)
3467 return (uint32_t)(READ_BITS(USBx->CTRL0, USB_CTRL0_PROBE_SEL));
3482 __STATIC_INLINE
void ll_usb_set_ep3_xfer_len(usb_regs_t *USBx, uint32_t len)
3484 MODIFY_REG(USBx->EP3_XFER_LEN, USB_EP3_XFER_LEN, len);
3498 __STATIC_INLINE uint32_t ll_usb_get_ep3_xfer_len(usb_regs_t *USBx)
3500 return (uint32_t)(READ_BITS(USBx->EP3_XFER_LEN, USB_EP3_XFER_LEN));
3515 __STATIC_INLINE
void ll_usb_set_ep4_xfer_len(usb_regs_t *USBx, uint32_t len)
3517 MODIFY_REG(USBx->EP4_XFER_LEN, USB_EP4_XFER_LEN, len);
3531 __STATIC_INLINE uint32_t ll_usb_get_ep4_xfer_len(usb_regs_t *USBx)
3533 return (uint32_t)(READ_BITS(USBx->EP4_XFER_LEN, USB_EP4_XFER_LEN));
3548 __STATIC_INLINE
void ll_usb_set_ep5_xfer_len(usb_regs_t *USBx, uint32_t len)
3550 MODIFY_REG(USBx->EP5_XFER_LEN, USB_EP5_XFER_LEN, len);
3564 __STATIC_INLINE uint32_t ll_usb_get_ep5_xfer_len(usb_regs_t *USBx)
3566 return (uint32_t)(READ_BITS(USBx->EP5_XFER_LEN, USB_EP5_XFER_LEN));
3581 __STATIC_INLINE
void ll_usb_set_ep5_timer_val(usb_regs_t *USBx, uint32_t len)
3583 MODIFY_REG(USBx->EP5_TIMER, USB_EP5_TIMER_VAL, len);
3597 __STATIC_INLINE uint32_t ll_usb_get_ep5_timer_val(usb_regs_t *USBx)
3599 return (uint32_t)(READ_BITS(USBx->EP5_TIMER, USB_EP5_TIMER_VAL));
3613 __STATIC_INLINE uint32_t ll_usb_get_ep0_rx_data_sum(usb_regs_t *USBx)
3615 return (uint32_t)(READ_BITS(USBx->RX_CNT, USB_RX_CNT_EP0_RX_DATA_SUM));
3629 __STATIC_INLINE uint32_t ll_usb_get_ep1_rx_data_sum(usb_regs_t *USBx)
3631 return (uint32_t)(READ_BITS(USBx->RX_CNT, USB_RX_CNT_EP1_RX_DATA_SUM) >> USB_RX_CNT_EP1_RX_DATA_SUM_Pos);
3645 __STATIC_INLINE uint32_t ll_usb_get_ep5_rx_data_sum(usb_regs_t *USBx)
3647 return (uint32_t)(READ_BITS(USBx->EP5_RX_CNT, USB_EP5_RX_CNT));
3662 __STATIC_INLINE
void ll_usb_set_cfg_desc_ctrl_start(usb_regs_t *USBx, uint32_t addr)
3664 MODIFY_REG(USBx->CFG_DESC_CTRL, USB_CFG_DESC_CTRL_START, addr);
3678 __STATIC_INLINE uint32_t ll_usb_get_cfg_desc_ctrl_start(usb_regs_t *USBx)
3680 return (uint32_t)(READ_BITS(USBx->CFG_DESC_CTRL, USB_CFG_DESC_CTRL_START));
3695 __STATIC_INLINE
void ll_usb_set_cfg_desc_ctrl_size(usb_regs_t *USBx, uint32_t size)
3697 MODIFY_REG(USBx->CFG_DESC_CTRL, USB_CFG_DESC_CTRL_SIZE, size << USB_CFG_DESC_CTRL_SIZE_Pos);
3711 __STATIC_INLINE uint32_t ll_usb_get_cfg_desc_ctrl_size(usb_regs_t *USBx)
3713 return (uint32_t)(READ_BITS(USBx->CFG_DESC_CTRL, USB_CFG_DESC_CTRL_SIZE) >> USB_CFG_DESC_CTRL_SIZE_Pos);
3728 __STATIC_INLINE
void ll_usb_set_str_desc0_ctrl_start(usb_regs_t *USBx, uint32_t addr)
3730 MODIFY_REG(USBx->STR_DESC0_CTRL, USB_STR_DESC0_CTRL_START, addr);
3744 __STATIC_INLINE uint32_t ll_usb_get_str_desc0_ctrl_start(usb_regs_t *USBx)
3746 return (uint32_t)(READ_BITS(USBx->STR_DESC0_CTRL, USB_STR_DESC0_CTRL_START));
3761 __STATIC_INLINE
void ll_usb_set_str_desc0_ctrl_size(usb_regs_t *USBx, uint32_t size)
3763 MODIFY_REG(USBx->STR_DESC0_CTRL, USB_STR_DESC0_CTRL_SIZE, size << USB_STR_DESC0_CTRL_SIZE_Pos);
3777 __STATIC_INLINE uint32_t ll_usb_get_str_desc0_ctrl_size(usb_regs_t *USBx)
3779 return (uint32_t)(READ_BITS(USBx->STR_DESC0_CTRL, USB_STR_DESC0_CTRL_SIZE) >> USB_STR_DESC0_CTRL_SIZE_Pos);
3794 __STATIC_INLINE
void ll_usb_set_str_desc1_ctrl_start(usb_regs_t *USBx, uint32_t addr)
3796 MODIFY_REG(USBx->STR_DESC1_CTRL, USB_STR_DESC1_CTRL_START, addr);
3810 __STATIC_INLINE uint32_t ll_usb_get_str_desc1_ctrl_start(usb_regs_t *USBx)
3812 return (uint32_t)(READ_BITS(USBx->STR_DESC1_CTRL, USB_STR_DESC1_CTRL_START));
3827 __STATIC_INLINE
void ll_usb_set_str_desc1_ctrl_size(usb_regs_t *USBx, uint32_t size)
3829 MODIFY_REG(USBx->STR_DESC1_CTRL, USB_STR_DESC1_CTRL_SIZE, size << USB_STR_DESC1_CTRL_SIZE_Pos);
3843 __STATIC_INLINE uint32_t ll_usb_get_str_desc1_ctrl_size(usb_regs_t *USBx)
3845 return (uint32_t)(READ_BITS(USBx->STR_DESC1_CTRL, USB_STR_DESC1_CTRL_SIZE) >> USB_STR_DESC1_CTRL_SIZE_Pos);
3860 __STATIC_INLINE
void ll_usb_set_usb_ep0_fifo(usb_regs_t *USBx, uint32_t value)
3862 MODIFY_REG(USBx->EP0_FIFO_ADDR, USB_EP0_FIFO_ADDR, value);
3876 __STATIC_INLINE uint32_t ll_usb_get_usb_ep0_fifo(usb_regs_t *USBx)
3878 return (uint32_t)(READ_BITS(USBx->EP0_FIFO_ADDR, USB_EP0_FIFO_ADDR));
3892 __STATIC_INLINE uint32_t ll_usb_get_usb_ep1_fifo(usb_regs_t *USBx)
3894 return (uint32_t)(READ_BITS(USBx->EP1_FIFO_ADDR, USB_EP1_FIFO_ADDR));
3909 __STATIC_INLINE
void ll_usb_set_usb_ep2_fifo(usb_regs_t *USBx, uint32_t value)
3911 MODIFY_REG(USBx->EP2_FIFO_ADDR, USB_EP2_FIFO_ADDR, value);
3926 __STATIC_INLINE
void ll_usb_set_usb_ep3_fifo(usb_regs_t *USBx, uint32_t value)
3928 MODIFY_REG(USBx->EP3_FIFO_ADDR, USB_EP3_FIFO_ADDR, value);
3943 __STATIC_INLINE
void ll_usb_set_usb_ep4_fifo(usb_regs_t *USBx, uint32_t value)
3945 MODIFY_REG(USBx->EP4_FIFO_ADDR, USB_EP4_FIFO_ADDR, value);
3959 __STATIC_INLINE uint32_t ll_usb_get_usb_ep5_fifo(usb_regs_t *USBx)
3961 return (uint32_t)(READ_BITS(USBx->EP5_FIFO_ADDR, USB_EP5_FIFO_ADDR));
3981 __STATIC_INLINE
void ll_usb_set_ep4_fifo_wr_en(usb_regs_t *USBx, uint32_t len)
3983 MODIFY_REG(USBx->EP4_FIFO_WR_EN, USB_EP4_FIFO_WR_EN, len);
4002 __STATIC_INLINE uint32_t ll_usb_get_ep4_fifo_wr_en(usb_regs_t *USBx)
4004 return (uint32_t)(READ_BITS(USBx->EP4_FIFO_WR_EN, USB_EP4_FIFO_WR_EN));
4019 __STATIC_INLINE
void ll_usb_set_usb_desc_sram_addr(usb_regs_t *USBx, uint32_t addr)
4021 MODIFY_REG(USBx->SRAM_ADDR, USB_SRAM_ADDR_DESC_SRAM, addr);
4036 __STATIC_INLINE
void ll_usb_set_str_desc2_ctrl_start(usb_regs_t *USBx, uint32_t addr)
4038 MODIFY_REG(USBx->STR_DESC2_CTRL, USB_STR_DESC2_CTRL_START, addr);
4052 __STATIC_INLINE uint32_t ll_usb_get_str_desc2_ctrl_start(usb_regs_t *USBx)
4054 return (uint32_t)(READ_BITS(USBx->STR_DESC2_CTRL, USB_STR_DESC2_CTRL_START));
4069 __STATIC_INLINE
void ll_usb_set_str_desc2_ctrl_size(usb_regs_t *USBx, uint32_t size)
4071 MODIFY_REG(USBx->STR_DESC2_CTRL, USB_STR_DESC2_CTRL_SIZE, size << USB_STR_DESC2_CTRL_SIZE_Pos);
4085 __STATIC_INLINE uint32_t ll_usb_get_str_desc2_ctrl_size(usb_regs_t *USBx)
4087 return (uint32_t)(READ_BITS(USBx->STR_DESC2_CTRL, USB_STR_DESC1_CTRL_SIZE) >> USB_STR_DESC2_CTRL_SIZE_Pos);
4102 __STATIC_INLINE
void ll_usb_set_str_desc3_ctrl_start(usb_regs_t *USBx, uint32_t addr)
4104 MODIFY_REG(USBx->STR_DESC3_CTRL, USB_STR_DESC3_CTRL_START, addr);
4118 __STATIC_INLINE uint32_t ll_usb_get_str_desc3_ctrl_start(usb_regs_t *USBx)
4120 return (uint32_t)(READ_BITS(USBx->STR_DESC3_CTRL, USB_STR_DESC3_CTRL_START));
4135 __STATIC_INLINE
void ll_usb_set_str_desc3_ctrl_size(usb_regs_t *USBx, uint32_t size)
4137 MODIFY_REG(USBx->STR_DESC3_CTRL, USB_STR_DESC3_CTRL_SIZE, size << USB_STR_DESC3_CTRL_SIZE_Pos);
4151 __STATIC_INLINE uint32_t ll_usb_get_str_desc3_ctrl_size(usb_regs_t *USBx)
4153 return (uint32_t)(READ_BITS(USBx->STR_DESC3_CTRL, USB_STR_DESC1_CTRL_SIZE) >> USB_STR_DESC3_CTRL_SIZE_Pos);
4161 void ll_usb_enable(
void);
4169 void ll_usb_disable(
void);
4184 error_status_t ll_usb_deinit(usb_regs_t *USBx);
4196 error_status_t ll_usb_init(usb_regs_t *USBx, ll_usb_init_t *p_usb_init);
4204 void ll_usb_struct_init(ll_usb_init_t *p_usb_init);