cancel
Showing results for 
Search instead for 
Did you mean: 

STM32F756 Alternate function

StanJerm
Associate III

Hi there, i come across AN4760 p55, configuring GPIOB with alternate functions :

GPIOB->AFR[0] = 0x0A000900;  where does this 0A000900 come to config PB2 n PB6 to QSPI alternate function?

GPIOB->AFR[1] = 0x00000000; 

....

GPIOF->AFR[0] |= 0x9900000000;  how this 9900000000 set to config PF6, PF7 PF8 PF9 to QSPI alt. function?

GPIOF->AFR[1] |= 0x000000AA  

Pls advise...thx.

1 ACCEPTED SOLUTION

Accepted Solutions
KDJEM.1
ST Employee

Hello @StanJerm ,

When you refer to RM0385 as already mentioned by @Issamos , the configuration of alternative function of PB2, PB6, PF6, PF7, PF7 and PF8 are made in GPIOx_AFRL (GPIOx->AFR[0])  and in GPIOx_AFRH (GPIOx->AFR[1]).

In this case:

-GPIOB configuration is done by: 

  • GPIOB->AFR[0] = 0x0A000900; is used to configure PB2 and PB6 to QSPI alternate function AF9 and AF10 respectively as shown in the below table:

GPIOB

PB pins

PB7

PB6

PB5

PB4

PB3

PB2

PB1

PB0

AFR[0]

0

A

0

0

0

9

0

0

0000

1010

0000

0000

0000

1001

0000

0000

Alternate Function

AF0

AF10

AF0

AF0

AF0

AF9

AF0

AF0

  • GPIOB->AFR[1] = 0x00000000; 

GPIOB

PB pins

PB15

PB14

PB13

PB12

PB11

PB10

PB9

PB8

AFR[1]

0

0

0

0

0

0

0

0

0000

0000

0000

0000

0000

0000

0000

0000

Alternate Function

AF0

AF0

AF0

AF0

AF0

AF0

AF0

AF0

-GPIOF configuration is done by: 

  • GPIOF->AFR[0] |= 0x99000000; is used to configure PF6 and PF7 to QSPI alternate function AF9 as shown in the below table:

GPIOF

PF pins

PF7

PF6

PF5

PF4

PF3

PF2

PF1

PF0

AFR[0]

9

9

0

0

0

0

0

0

1001

1001

0000

0000

0000

0000

0000

0000

Alternate Function

AF9

AF9

AF0

AF0

AF0

AF0

AF0

AF0

  • GPIOF->AFR[1] |= 0x000000AA ; is used to configure PF8 and PF9 to QSPI alternate function AF10 as shown in the below table:

GPIOF

PF pins

PF15

PF14

PF13

PF12

PF11

PF10

PF9

PF8

AFR[0]

0

0

0

0

0

0

A

A

0000

0000

0000

0000

0000

0000

1010

1010

Alternate Function

AF0

AF0

AF0

AF0

AF0

AF0

AF10

AF10

Thank you.

Kaouthar

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.

View solution in original post

4 REPLIES 4
Issamos
Lead II

Hello @StanJerm 

The board and the quad-spi flash memory are connected like this:

Screenshot_2023-09-07-16-57-55-56_e2d5b3f32b79de1d45acd1fad96fbb0f.jpg

Then we have to programme every pin to the alternate function that it should be using. Taking a look to the DocID027589 Rev 4 (datasheet of the STM32F756) we find out that PB2, PF6 and PF7 should be configured to AF9 and PB6, PF8 and PF9 should be configured to AF10. Then and using the GPIO alternate function low register (GPIOx_AFRL) and GPIO alternate function high register (GPIOx_AFRH) we have to do this configuration. Wish is the same as the Alternate function configuration in the AN4760. ( have a look at RM0385)

Screenshot_2023-09-07-17-00-34-33_e2d5b3f32b79de1d45acd1fad96fbb0f.jpg

Screenshot_2023-09-07-17-01-08-23_e2d5b3f32b79de1d45acd1fad96fbb0f.jpg

Screenshot_2023-09-07-17-01-26-39_e2d5b3f32b79de1d45acd1fad96fbb0f.jpg

 best regards.

II

Sorry, got no familiarity with your code or situation. Maybe you can expand on the detail so we understand the context better?

Often configured via Cube MSP code, or HAL GPIO Init functions. Can be a hold-over from external loaders or debug scripts, or boot loader, if they are bringing up the board.

Generally you'd want to mask on new settings, ORing tends to presume the original content is zero

Tips, Buy me a coffee, or three.. PayPal Venmo
Up vote any posts that you find helpful, it shows what's working..
KDJEM.1
ST Employee

Hello @StanJerm ,

When you refer to RM0385 as already mentioned by @Issamos , the configuration of alternative function of PB2, PB6, PF6, PF7, PF7 and PF8 are made in GPIOx_AFRL (GPIOx->AFR[0])  and in GPIOx_AFRH (GPIOx->AFR[1]).

In this case:

-GPIOB configuration is done by: 

  • GPIOB->AFR[0] = 0x0A000900; is used to configure PB2 and PB6 to QSPI alternate function AF9 and AF10 respectively as shown in the below table:

GPIOB

PB pins

PB7

PB6

PB5

PB4

PB3

PB2

PB1

PB0

AFR[0]

0

A

0

0

0

9

0

0

0000

1010

0000

0000

0000

1001

0000

0000

Alternate Function

AF0

AF10

AF0

AF0

AF0

AF9

AF0

AF0

  • GPIOB->AFR[1] = 0x00000000; 

GPIOB

PB pins

PB15

PB14

PB13

PB12

PB11

PB10

PB9

PB8

AFR[1]

0

0

0

0

0

0

0

0

0000

0000

0000

0000

0000

0000

0000

0000

Alternate Function

AF0

AF0

AF0

AF0

AF0

AF0

AF0

AF0

-GPIOF configuration is done by: 

  • GPIOF->AFR[0] |= 0x99000000; is used to configure PF6 and PF7 to QSPI alternate function AF9 as shown in the below table:

GPIOF

PF pins

PF7

PF6

PF5

PF4

PF3

PF2

PF1

PF0

AFR[0]

9

9

0

0

0

0

0

0

1001

1001

0000

0000

0000

0000

0000

0000

Alternate Function

AF9

AF9

AF0

AF0

AF0

AF0

AF0

AF0

  • GPIOF->AFR[1] |= 0x000000AA ; is used to configure PF8 and PF9 to QSPI alternate function AF10 as shown in the below table:

GPIOF

PF pins

PF15

PF14

PF13

PF12

PF11

PF10

PF9

PF8

AFR[0]

0

0

0

0

0

0

A

A

0000

0000

0000

0000

0000

0000

1010

1010

Alternate Function

AF0

AF0

AF0

AF0

AF0

AF0

AF10

AF10

Thank you.

Kaouthar

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.

THX U very much