cancel
Showing results for 
Search instead for 
Did you mean: 

Cannot set PC14 and PC15 as output GPIO on STM32F401

m864cdf4ac
Associate II

Hello,

due to pin shortage, I (foolishly) used pin PC14 and PC15 as output GPIOs on a board that I designed and my colleague is writing the firmware. We never use them previously, due to the all problems with limited sourcing caused by internal backup domain power switch and their low-speed limits. For the current board, the low speed and low drive was no issue.

But now there is a problem - we are unable to get the pins working. I tried the code generated by CubeMX and my colleague, who uses own routines, used the approach described on several pages on the web - first disable the LSE in BDCR by cleaning the LSEON bit, wait for LSE deactivation, turn on the backup domain power, enable access by setting DBP bit, and finally normally set the pins as low-speed push-pull outputs. We tried all this, but the pins stay low all the time. For testing, we used a NUCLEO-F401RE, because the board is still being manufactured.

Could be the absence of the HSE crystal (or, a TCXO on our board) the culprit? We previously had problems to get the RTC working without the HSE. Note that the crystal (X2) on the NUCLEO-F401RE is not populated and both code runs with HSI RC.

1 ACCEPTED SOLUTION

Accepted Solutions
m864cdf4ac
Associate II

Yes, the bridges, namely SB48 and SB49, situated on the bottom side of the board, were open. When I closed them by a blob of solder, the signals on PC14 and PC15 appeared, even with the 32K crystal X2 still attached (as I expected, its tiny capacity caused no problems with the 10 Hz test signal).

So folks, if you are using the NUCLEO-F401RE and are about to use the PC14 and PC15, you need to close the bridges SB48 and SB49 on the bottom side of the board. You may unsolder the crystal X2 but due to limits of these pins (low speed only), you will probably not have to.

View solution in original post

6 REPLIES 6
SofLit
ST Employee

Hello @m864cdf4ac and welcome to the community.

For your information. From the datasheet / Table 8 / note 2:

SofLit_0-1736954969793.png

 

To give better visibility on the answered topics, please click on "Accept as Solution" on the reply which solved your issue or answered your question.
PS: This is NOT an online support (https://ols.st.com) but a collaborative space. So please be polite in your reply. Otherwise, it will be reported as inappropriate and you will be permanently blacklisted from my help/support.

Yes, we now this. This is the reason that we use the PC13 only as an activity ("blinky") LED, which draws barely tens of microamperes only (it's a very efficient LED). The catch is - the PC13 works without problems, the PC14 and PC15 don't.

Read out and check/post content of RCC_BDCR and GPIOC registers.

Make sure the jumpers/solder bridges on the board are disconnected from crystal and connected to whatever point you are measuring at (probably the pinheaders). See manual/schematics of board.

JW

I will check the bridges (the schematics show them as open by default and I am not sure if my colleague closed them), but IMHO the 32 768 Hz crystal could be happily ignored for DC/low-frequency signals (we tested with continuous H and 10 Hz square wave), because its capacity is only tens of picofarads and even low-current pin should be able to drive such load without problem.

m864cdf4ac
Associate II

Yes, the bridges, namely SB48 and SB49, situated on the bottom side of the board, were open. When I closed them by a blob of solder, the signals on PC14 and PC15 appeared, even with the 32K crystal X2 still attached (as I expected, its tiny capacity caused no problems with the 10 Hz test signal).

So folks, if you are using the NUCLEO-F401RE and are about to use the PC14 and PC15, you need to close the bridges SB48 and SB49 on the bottom side of the board. You may unsolder the crystal X2 but due to limits of these pins (low speed only), you will probably not have to.

Thanks for coming back with the solution. Please click on "Accept as solution" in that post so that the thread is marked as solved.

JW