Hi,
I am facing a problem with the PB14 pin set as a GPIO and the USB HS with external PHY. I am using the PB14 to control a relay and USB communication using the ULPI interface (external PHY). For what we understand if the USB is using ULPI then PB14 and PB15 should be free to be used as GPIO, but after the USB_Connect function is executed the PB14 seems to be taken by the USB driver or library.
I know is a problem with the USB driver that is powering ON the internal PHY (setting bit PWRDWN of OTG_HS_GCCFG register) even it is configured to used the external one, I just do not remember the workaround for this issue. I need to reinstall the complete environment in a new computer so I lost the configuration was working. I am using the MDK-Pro variant with USB driver version 6.2.0 and cannot upgrade it since it will involve a major overhaul of the existing code.
on the RTE_Device.h file the defines RTE_USB_OTG_HS and RTE_USB_OTG_HS_PHY are set to 1, this to use the HS interface with the external PHY... but as I said the function USBD_Connect() is overriding this setting and turning on the internal PHY making the pin PB14 useless.
Looking on the internet it seems another people with similar problems it seems that issue is on the USB driver but we cannot longer access the post they have (below a link to what we found).... Can you please let us know how to solve this?
https://community.st.com/t5/stm32-mcus-products/stm32f4xx-spi2-and-usb-hs-conflict/td-p/438246
Regards
Mark Burger
Hi Mark,
on the ST forum there is a similar question in https://community.st.com/t5/stm32-mcus-embedded-software/stm32f4-use-usb-dp-and-dm-as-gpios/m-p/363311
So, you should try manually edit the USB driver file and comment-out the line that sets PWRDWN bit in the OTG_HS_GCCFG register.
Hi Milorad,
Thanks for the advice, actually I solved it yesterday by doing something similar. I modified the define OTG_HS_GCCFG_PWRDWN on the driver file OTG_HS_STM32F4xx.h to set a 0 instead of a 1 on this bit... this makes the driver to turn off the internal PHY.
Not elegant but works, I will try to find a more suitable solution and if find it post it here for future reference. Perhaps adding a if that verifies if the external PHY is in use will be more elegant, but possibly this involves a more complex driver fix.
Thanks a lot for the advice!!!
glad you solved the issue.
Anyways, the driver you worked with is not used anymore, latest drivers are STM32 HAL based and depend on the STM32CubeMX generated code so there I don't think it makes sense for you to spend more time and provide a fix for wider audience.
You can check the new drivers on the following GitHub repository: github.com/.../CMSIS-Driver_STM32