correct HSE_VALUE in hal_conf
- although it is define in CFLAGS, it is worth to correct to be consistent with other build - extract set_speed()
This commit is contained in:
		| @@ -39,7 +39,7 @@ The stack supports the following MCUs: | |||||||
|   - LPC Series: 11Uxx, 13xx, 175x_6x, 177x_8x, 18xx, 40xx, 43xx, 51Uxx, 54xxx, 55xx |   - LPC Series: 11Uxx, 13xx, 175x_6x, 177x_8x, 18xx, 40xx, 43xx, 51Uxx, 54xxx, 55xx | ||||||
|   - iMX RT Series: RT1011, RT1015, RT1021, RT1052, RT1062, RT1064 |   - iMX RT Series: RT1011, RT1015, RT1021, RT1052, RT1062, RT1064 | ||||||
| - **Sony:** CXD56 | - **Sony:** CXD56 | ||||||
| - **ST:** STM32 series: L0, F0, F1, F2, F3, F4, F7, H7 (device only) | - **ST:** STM32 series: L0, F0, F1, F2, F3, F4, F7, H7 both FullSpeed and HighSpeed | ||||||
| - **TI:** MSP430 | - **TI:** MSP430 | ||||||
| - **[ValentyUSB](https://github.com/im-tomu/valentyusb)** eptri | - **[ValentyUSB](https://github.com/im-tomu/valentyusb)** eptri | ||||||
|  |  | ||||||
|   | |||||||
| @@ -85,6 +85,7 @@ This code base already had supported for a handful of following boards (sorted a | |||||||
|  |  | ||||||
| - [Adafruit Feather STM32F405](https://www.adafruit.com/product/4382) | - [Adafruit Feather STM32F405](https://www.adafruit.com/product/4382) | ||||||
| - [Micro Python PyBoard v1.1](https://store.micropython.org/product/PYBv1.1) | - [Micro Python PyBoard v1.1](https://store.micropython.org/product/PYBv1.1) | ||||||
|  | - [STLink-V3 Mini](https://www.st.com/en/development-tools/stlink-v3mini.html) | ||||||
| - [STM32 L035c8 Discovery](https://www.st.com/en/evaluation-tools/32l0538discovery.html) | - [STM32 L035c8 Discovery](https://www.st.com/en/evaluation-tools/32l0538discovery.html) | ||||||
| - [STM32 F070rb Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f070rb.html) | - [STM32 F070rb Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f070rb.html) | ||||||
| - [STM32 F072rb Discovery](https://www.st.com/en/evaluation-tools/32f072bdiscovery.html) | - [STM32 F072rb Discovery](https://www.st.com/en/evaluation-tools/32f072bdiscovery.html) | ||||||
| @@ -96,9 +97,13 @@ This code base already had supported for a handful of following boards (sorted a | |||||||
| - STM32 F411ce Black Pill | - STM32 F411ce Black Pill | ||||||
| - [STM32 F411ve Discovery](https://www.st.com/en/evaluation-tools/32f411ediscovery.html) | - [STM32 F411ve Discovery](https://www.st.com/en/evaluation-tools/32f411ediscovery.html) | ||||||
| - [STM32 F412zg Discovery](https://www.st.com/en/evaluation-tools/32f412gdiscovery.html) | - [STM32 F412zg Discovery](https://www.st.com/en/evaluation-tools/32f412gdiscovery.html) | ||||||
|  | - [STM32 F723e Discovery](https://www.st.com/en/evaluation-tools/32f723ediscovery.html) | ||||||
| - [STM32 F746zg Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f746zg.html) | - [STM32 F746zg Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f746zg.html) | ||||||
|  | - [STM32 F746g Discovery](https://www.st.com/en/evaluation-tools/32f746gdiscovery.html) | ||||||
| - [STM32 F767zi Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f767zi.html) | - [STM32 F767zi Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f767zi.html) | ||||||
|  | - [STM32 F769i Discovery](https://www.st.com/en/evaluation-tools/32f769idiscovery.html) | ||||||
| - [STM32 H743zi Nucleo](https://www.st.com/en/evaluation-tools/nucleo-h743zi.html) | - [STM32 H743zi Nucleo](https://www.st.com/en/evaluation-tools/nucleo-h743zi.html) | ||||||
|  | - [STM32 H743i Evaluation](https://www.st.com/en/evaluation-tools/stm32h743i-eval.html) | ||||||
|  |  | ||||||
| ### TI | ### TI | ||||||
|  |  | ||||||
|   | |||||||
| @@ -87,7 +87,7 @@ | |||||||
|   *        (when HSE is used as system clock source, directly or through the PLL). |   *        (when HSE is used as system clock source, directly or through the PLL). | ||||||
|   */ |   */ | ||||||
| #if !defined  (HSE_VALUE) | #if !defined  (HSE_VALUE) | ||||||
|   #define HSE_VALUE    ((uint32_t)8000000U) /*!< Value of the External oscillator in Hz */ |   #define HSE_VALUE    ((uint32_t)25000000U) /*!< Value of the External oscillator in Hz */ | ||||||
| #endif /* HSE_VALUE */ | #endif /* HSE_VALUE */ | ||||||
|  |  | ||||||
| #if !defined  (HSE_STARTUP_TIMEOUT) | #if !defined  (HSE_STARTUP_TIMEOUT) | ||||||
|   | |||||||
| @@ -87,7 +87,7 @@ | |||||||
|   *        (when HSE is used as system clock source, directly or through the PLL). |   *        (when HSE is used as system clock source, directly or through the PLL). | ||||||
|   */ |   */ | ||||||
| #if !defined  (HSE_VALUE) | #if !defined  (HSE_VALUE) | ||||||
|   #define HSE_VALUE    ((uint32_t)8000000U) /*!< Value of the External oscillator in Hz */ |   #define HSE_VALUE    ((uint32_t)25000000U) /*!< Value of the External oscillator in Hz */ | ||||||
| #endif /* HSE_VALUE */ | #endif /* HSE_VALUE */ | ||||||
|  |  | ||||||
| #if !defined  (HSE_STARTUP_TIMEOUT) | #if !defined  (HSE_STARTUP_TIMEOUT) | ||||||
|   | |||||||
| @@ -87,7 +87,7 @@ | |||||||
|   *        (when HSE is used as system clock source, directly or through the PLL). |   *        (when HSE is used as system clock source, directly or through the PLL). | ||||||
|   */ |   */ | ||||||
| #if !defined  (HSE_VALUE) | #if !defined  (HSE_VALUE) | ||||||
|   #define HSE_VALUE    ((uint32_t)8000000U) /*!< Value of the External oscillator in Hz */ |   #define HSE_VALUE    ((uint32_t)25000000U) /*!< Value of the External oscillator in Hz */ | ||||||
| #endif /* HSE_VALUE */ | #endif /* HSE_VALUE */ | ||||||
|  |  | ||||||
| #if !defined  (HSE_STARTUP_TIMEOUT) | #if !defined  (HSE_STARTUP_TIMEOUT) | ||||||
|   | |||||||
| @@ -285,12 +285,74 @@ static void set_turnaround(USB_OTG_GlobalTypeDef * usb_otg, tusb_speed_t speed) | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| static tusb_speed_t get_speed(USB_OTG_DeviceTypeDef* dev) | static tusb_speed_t get_speed(uint8_t rhport) | ||||||
| { | { | ||||||
|  |   USB_OTG_DeviceTypeDef * dev = DEVICE_BASE(rhport); | ||||||
|   uint32_t const enum_spd = (dev->DSTS & USB_OTG_DSTS_ENUMSPD_Msk) >> USB_OTG_DSTS_ENUMSPD_Pos; |   uint32_t const enum_spd = (dev->DSTS & USB_OTG_DSTS_ENUMSPD_Msk) >> USB_OTG_DSTS_ENUMSPD_Pos; | ||||||
|   return (enum_spd == DCD_HIGH_SPEED) ? TUSB_SPEED_HIGH : TUSB_SPEED_FULL; |   return (enum_spd == DCD_HIGH_SPEED) ? TUSB_SPEED_HIGH : TUSB_SPEED_FULL; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | static void set_speed(uint8_t rhport, tusb_speed_t speed) | ||||||
|  | { | ||||||
|  |   uint32_t bitvalue; | ||||||
|  |  | ||||||
|  |   if ( rhport == 1 ) | ||||||
|  |   { | ||||||
|  |     bitvalue = ((TUSB_SPEED_HIGH == speed) ? DCD_HIGH_SPEED : DCD_FULL_SPEED_USE_HS); | ||||||
|  |   } | ||||||
|  |   else | ||||||
|  |   { | ||||||
|  |     bitvalue = DCD_FULL_SPEED; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   USB_OTG_DeviceTypeDef * dev = DEVICE_BASE(rhport); | ||||||
|  |  | ||||||
|  |   // Clear and set speed bits | ||||||
|  |   dev->DCFG &= ~(3 << USB_OTG_DCFG_DSPD_Pos); | ||||||
|  |   dev->DCFG |= (bitvalue << USB_OTG_DCFG_DSPD_Pos); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #if defined(USB_HS_PHYC) && TUD_OPT_HIGH_SPEED | ||||||
|  | static bool USB_HS_PHYCInit(void) | ||||||
|  | { | ||||||
|  |   USB_HS_PHYC_GlobalTypeDef *usb_hs_phyc = (USB_HS_PHYC_GlobalTypeDef*) USB_HS_PHYC_CONTROLLER_BASE; | ||||||
|  |  | ||||||
|  |   // Enable LDO | ||||||
|  |   usb_hs_phyc->USB_HS_PHYC_LDO |= USB_HS_PHYC_LDO_ENABLE; | ||||||
|  |  | ||||||
|  |   // Wait until LDO ready | ||||||
|  |   while ( 0 == (usb_hs_phyc->USB_HS_PHYC_LDO & USB_HS_PHYC_LDO_STATUS) ) {} | ||||||
|  |  | ||||||
|  |   uint32_t phyc_pll = 0; | ||||||
|  |  | ||||||
|  |   // TODO Try to get HSE_VALUE from registers instead of depending CFLAGS | ||||||
|  |   switch ( HSE_VALUE ) | ||||||
|  |   { | ||||||
|  |     case 12000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_12MHZ   ; break; | ||||||
|  |     case 12500000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_12_5MHZ ; break; | ||||||
|  |     case 16000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_16MHZ   ; break; | ||||||
|  |     case 24000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_24MHZ   ; break; | ||||||
|  |     case 25000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_25MHZ   ; break; | ||||||
|  |     case 32000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_Msk     ; break; // Value not defined in header | ||||||
|  |     default: | ||||||
|  |       TU_ASSERT(0); | ||||||
|  |   } | ||||||
|  |   usb_hs_phyc->USB_HS_PHYC_PLL = phyc_pll; | ||||||
|  |  | ||||||
|  |   // Control the tuning interface of the High Speed PHY | ||||||
|  |   // Use magic value from ST driver | ||||||
|  |   usb_hs_phyc->USB_HS_PHYC_TUNE |= 0x00000F13U; | ||||||
|  |  | ||||||
|  |   // Enable PLL internal PHY | ||||||
|  |   usb_hs_phyc->USB_HS_PHYC_PLL |= USB_HS_PHYC_PLL_PLLEN; | ||||||
|  |  | ||||||
|  |   // Original ST code has 2 ms delay for PLL stabilization. | ||||||
|  |   // Primitive test shows that more than 10 USB un/replug cycle showed no error with enumeration | ||||||
|  |  | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| static void edpt_schedule_packets(uint8_t rhport, uint8_t const epnum, uint8_t const dir, uint16_t const num_packets, uint16_t total_bytes) { | static void edpt_schedule_packets(uint8_t rhport, uint8_t const epnum, uint8_t const dir, uint16_t const num_packets, uint16_t total_bytes) { | ||||||
|   USB_OTG_DeviceTypeDef * dev = DEVICE_BASE(rhport); |   USB_OTG_DeviceTypeDef * dev = DEVICE_BASE(rhport); | ||||||
|   USB_OTG_OUTEndpointTypeDef * out_ep = OUT_EP_BASE(rhport); |   USB_OTG_OUTEndpointTypeDef * out_ep = OUT_EP_BASE(rhport); | ||||||
| @@ -325,46 +387,6 @@ static void edpt_schedule_packets(uint8_t rhport, uint8_t const epnum, uint8_t c | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| #if defined(USB_HS_PHYC) && TUD_OPT_HIGH_SPEED |  | ||||||
| static bool USB_HS_PHYCInit(void) |  | ||||||
| { |  | ||||||
|   USB_HS_PHYC_GlobalTypeDef *usb_hs_phyc = (USB_HS_PHYC_GlobalTypeDef*) USB_HS_PHYC_CONTROLLER_BASE; |  | ||||||
|  |  | ||||||
|   // Enable LDO |  | ||||||
|   usb_hs_phyc->USB_HS_PHYC_LDO |= USB_HS_PHYC_LDO_ENABLE; |  | ||||||
|  |  | ||||||
|   // Wait until LDO ready |  | ||||||
|   while ( 0 == (usb_hs_phyc->USB_HS_PHYC_LDO & USB_HS_PHYC_LDO_STATUS) ) {} |  | ||||||
|  |  | ||||||
|   uint32_t phyc_pll = 0; |  | ||||||
|   switch ( HSE_VALUE ) |  | ||||||
|   { |  | ||||||
|     case 12000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_12MHZ   ; break; |  | ||||||
|     case 12500000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_12_5MHZ ; break; |  | ||||||
|     case 16000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_16MHZ   ; break; |  | ||||||
|     case 24000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_24MHZ   ; break; |  | ||||||
|     case 25000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_25MHZ   ; break; |  | ||||||
|     case 32000000: phyc_pll = USB_HS_PHYC_PLL1_PLLSEL_Msk     ; break; // Value not defined in header |  | ||||||
|     default: |  | ||||||
|       TU_ASSERT(0); |  | ||||||
|   } |  | ||||||
|   usb_hs_phyc->USB_HS_PHYC_PLL = phyc_pll; |  | ||||||
|  |  | ||||||
|   // Control the tuning interface of the High Speed PHY |  | ||||||
|   // Use magic value from ST driver |  | ||||||
|   usb_hs_phyc->USB_HS_PHYC_TUNE |= 0x00000F13U; |  | ||||||
|  |  | ||||||
|   // Enable PLL internal PHY |  | ||||||
|   usb_hs_phyc->USB_HS_PHYC_PLL |= USB_HS_PHYC_PLL_PLLEN; |  | ||||||
|  |  | ||||||
|   // Original ST code has 2 ms delay for PLL stabilization. |  | ||||||
|   // Primitive test shows that more than 10 USB un/replug cycle showed no error with enumeration |  | ||||||
|  |  | ||||||
|   return true; |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| /*------------------------------------------------------------------*/ | /*------------------------------------------------------------------*/ | ||||||
| /* Controller API | /* Controller API | ||||||
|  *------------------------------------------------------------------*/ |  *------------------------------------------------------------------*/ | ||||||
| @@ -431,21 +453,10 @@ void dcd_init (uint8_t rhport) | |||||||
|   // (non zero-length packet), send STALL back and discard. |   // (non zero-length packet), send STALL back and discard. | ||||||
|   dev->DCFG |=  USB_OTG_DCFG_NZLSOHSK; |   dev->DCFG |=  USB_OTG_DCFG_NZLSOHSK; | ||||||
|  |  | ||||||
|   // Clear speed bits |   set_speed(rhport, TUD_OPT_HIGH_SPEED ? TUSB_SPEED_HIGH : TUSB_SPEED_FULL); | ||||||
|   dev->DCFG &= ~(3 << USB_OTG_DCFG_DSPD_Pos); |  | ||||||
|  |  | ||||||
|   if ( rhport == 1 ) |   // Enable internal USB transceiver. | ||||||
|   { |   if ( rhport == 0 ) usb_otg->GCCFG |= USB_OTG_GCCFG_PWRDWN; | ||||||
|     dev->DCFG |= ((TUD_OPT_HIGH_SPEED ? DCD_HIGH_SPEED : DCD_FULL_SPEED_USE_HS) << USB_OTG_DCFG_DSPD_Pos); |  | ||||||
|   } |  | ||||||
|   else |  | ||||||
|   { |  | ||||||
|     // full speed = 0x03 |  | ||||||
|     dev->DCFG |= (DCD_FULL_SPEED << USB_OTG_DCFG_DSPD_Pos); |  | ||||||
|  |  | ||||||
|     // Enable internal USB transceiver. |  | ||||||
|     usb_otg->GCCFG |= USB_OTG_GCCFG_PWRDWN; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   usb_otg->GINTMSK |= USB_OTG_GINTMSK_USBRST   | USB_OTG_GINTMSK_ENUMDNEM | |   usb_otg->GINTMSK |= USB_OTG_GINTMSK_USBRST   | USB_OTG_GINTMSK_ENUMDNEM | | ||||||
|                       USB_OTG_GINTMSK_USBSUSPM | USB_OTG_GINTMSK_WUIM     | |                       USB_OTG_GINTMSK_USBSUSPM | USB_OTG_GINTMSK_WUIM     | | ||||||
| @@ -511,7 +522,7 @@ bool dcd_edpt_open (uint8_t rhport, tusb_desc_endpoint_t const * desc_edpt) | |||||||
|   TU_ASSERT(epnum < EP_MAX); |   TU_ASSERT(epnum < EP_MAX); | ||||||
|  |  | ||||||
|   // TODO ISO endpoint can be up to 1024 bytes |   // TODO ISO endpoint can be up to 1024 bytes | ||||||
|   TU_ASSERT(desc_edpt->wMaxPacketSize.size <= (get_speed(dev) == TUSB_SPEED_HIGH ? 512 : 64)); |   TU_ASSERT(desc_edpt->wMaxPacketSize.size <= (get_speed(rhport) == TUSB_SPEED_HIGH ? 512 : 64)); | ||||||
|  |  | ||||||
|   xfer_ctl_t * xfer = XFER_CTL_BASE(epnum, dir); |   xfer_ctl_t * xfer = XFER_CTL_BASE(epnum, dir); | ||||||
|   xfer->max_size = desc_edpt->wMaxPacketSize.size; |   xfer->max_size = desc_edpt->wMaxPacketSize.size; | ||||||
| @@ -575,9 +586,6 @@ bool dcd_edpt_open (uint8_t rhport, tusb_desc_endpoint_t const * desc_edpt) | |||||||
|  |  | ||||||
|     _allocated_fifo_words += fifo_size; |     _allocated_fifo_words += fifo_size; | ||||||
|  |  | ||||||
|     //TU_LOG2_INT(fifo_size); |  | ||||||
|     //TU_LOG2_INT(_allocated_fifo_words); |  | ||||||
|  |  | ||||||
|     in_ep[epnum].DIEPCTL |= (1 << USB_OTG_DIEPCTL_USBAEP_Pos) | |     in_ep[epnum].DIEPCTL |= (1 << USB_OTG_DIEPCTL_USBAEP_Pos) | | ||||||
|                             (epnum << USB_OTG_DIEPCTL_TXFNUM_Pos) | |                             (epnum << USB_OTG_DIEPCTL_TXFNUM_Pos) | | ||||||
|                             (desc_edpt->bmAttributes.xfer << USB_OTG_DIEPCTL_EPTYP_Pos) | |                             (desc_edpt->bmAttributes.xfer << USB_OTG_DIEPCTL_EPTYP_Pos) | | ||||||
| @@ -925,7 +933,7 @@ void dcd_int_handler(uint8_t rhport) | |||||||
|  |  | ||||||
|     usb_otg->GINTSTS = USB_OTG_GINTSTS_ENUMDNE; |     usb_otg->GINTSTS = USB_OTG_GINTSTS_ENUMDNE; | ||||||
|  |  | ||||||
|     tusb_speed_t const speed = get_speed(dev); |     tusb_speed_t const speed = get_speed(rhport); | ||||||
|  |  | ||||||
|     set_turnaround(usb_otg, speed); |     set_turnaround(usb_otg, speed); | ||||||
|     dcd_event_bus_reset(rhport, speed, true); |     dcd_event_bus_reset(rhport, speed, true); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach