Skip to content

Latest commit

 

History

History

stm32f446

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

stm32f446

Any 180MHz STM32F4 series will work.

  • STM32F427
  • STM32F429
  • STM32F437
  • STM32F439
  • STM32F446
  • STM32F469
  • STM32F479

I used this as a reference.

Changes from the original

  • frame format
    This example support Extended frame format: with 29 identifier bits.

  • CAN port
    In this example, you can select the CAN port.

  • CAN1 and CAN2
    In this example, you can use CAN1 and CAN2 port.

Remap CAN port

STM32F446 has two CAN ports.
You can use only CAN1 or both CAN1 and CAN2, but you cannot use only CAN2.

These GPIOs can be used as CAN.

CAN RX TX
CAN1 PA11 PA12
CAN1 PB8 PB9
CAN1 PD0 PD1
CAN2 PB5 PB6
CAN2 PB12 PB13

STM32F427/429/437/439/469/479 has two CAN ports.
These GPIOs can be used as CAN.

CAN RX TX
CAN1 PA11 PA12
CAN1 PB8 PB9
CAN1 PD0 PD1
CAN1 PI9 PH13 Not supported
CAN2 PB5 PB6
CAN2 PB12 PB13

CAN1_RX mapped to PA11, CAN1_TX mapped to PA12
CAN2_RX mapped to PB5 , CAN2_TX mapped to PB6

CANInit(CAN_1000KBPS, 0);  // CAN_RX mapped to PA11, CAN_TX mapped to PA12

CAN1_RX mapped to PB8 , CAN1_TX mapped to PB9 (not available on 36-pin package)
CAN2_RX mapped to PB12, CAN2_TX mapped to PB13(not available on 36-pin package)

CANInit(CAN_1000KBPS, 2);  // CAN_RX mapped to PB8, CAN_TX mapped to PB9

CAN1_RX mapped to PD0 , CAN1_TX mapped to PD1 (available on 100-pin and 144-pin package)
CAN2_RX mapped to PB12, CAN2_TX mapped to PB13(not available on 36-pin package)

CANInit(CAN_1000KBPS, 3);  // CAN_RX mapped to PD0, CAN_TX mapped to PD1