stm32duino / Arduino_Core_STM32

STM32 core support for Arduino
https://github.com/stm32duino/Arduino_Core_STM32/wiki
Other
2.86k stars 980 forks source link

STM32F411CE doesn't seem to work #876

Closed TzOk83 closed 4 years ago

TzOk83 commented 4 years ago

I've tried to upload BLINK example (I've changed LED_BUILTIN to PC13) using "Generic F411CE" Board profile to the "Black Pill" WeAct V2.0 board (STM32F411CEU6), and it doesn't seem to work. I've also tried turning the USB support as CDC Generic Serial, but there was no serial port after uploading this firmware. I've tried uploading either by SWD (ST-Link v2) or by USB-DFU. Both times the upload was successful, but program didn't seem to start (of course I have tried to reset and power cycle the MPU).

fpistm commented 4 years ago

Hi @TzOk83 it seems a clock config issue. You can try to reconfigure it defining the SystemClock_Configat sketch level:

extern "C" void SystemClock_Config(void)
{
...
}
flatpedals commented 4 years ago

I have a WeAct 1.3 411CE and I can upload in Arduino IDE and PlatformIO via DFU (STM32Cube prog) and Serial(USB to TTL dongle). ArduinoIDE: 'Blackpill F401CC' under 'Generic STM32F4 series' generic

PlatformIO: edited 'BlackPill 401CC (ST)' to a 'BlackPill 411CE (ST)'. blackpill_f411ceJSON(PIO).zip

As I said DFU and Serial are working, then there is a working Serial Port available (STM Serial) while uploaded sketch is running.

I updated the core and the new 'Generic F411CC' showed up in board manager for a short while but now it's gone, so I can't select it to see if it's a problem vs the 'Blackpill F401CC'.

All good with this board untill now, maybe a STM32DUINO Bootloader would be nice so BOOT0 isn't required at every upload. I also soldered a Winbond 25q32jv and the SMD cap but never got to test that SPI memory.

Edited: Maybe try erasing your chip memory and also reinstall all the STM drivers (Show hidden devices in Device Manager and clean everything related). I erased and flashed via DFU (STM32CubeProg) a lot of times while testing the WeAct HID bootloader and STM32 HID bootloader. They are both useless in Arduino IDE. The STM32 HID seems to allow successful flashing but the MCU is never reset and the sketch doesn't run. I have to erase memory to get it out of that frozen state. WeAct HID is different since it's flashed at a different address. Stuck with DFU and Serial for now...

More edits: I updated the core and reinstalled boards, now a series of 'Generic 401xx' show up, but no 'Generic 411xx'. 'BlackPill 401CC' is still working. Also, the Serial Port is broken in PlatformIO after upload, something to do with USB CDC. So only in Arduino IDE with CDC mode selected there is a working com port.

Last edit, I promise: Fixed USB CDC in PlatformIO, requires this platformio.ini: `[env:blackpill_f411ce] platform = ststm32 board = blackpill_f411ce framework = arduino

upload_protocol = dfu upload_port = anything

build_flags = -D PIO_FRAMEWORK_ARDUINO_ENABLE_CDC -D USBCON -D USBD_VID=0x0483 -D USB_MANUFACTURER="Unknown" -D USB_PRODUCT="\"BLACKPILL_411CE\"" -D HAL_PCD_MODULE_ENABLED`

fpistm commented 4 years ago

@flatpedals the Generic F411Cx has been added recently and is merged in the master: #866

MCUdude commented 4 years ago

By looking at the pictures of the F411C "Black Pill" board on this Aliexpress listing It appears to me that the external crystal is running at 25 MHz. The generic pinouts expect an 8 MHz crystal/clock.

You can try to change the value of this line to 25 (actual input clock frequency in MHz) and see if it makes a difference. Oh, you'll have to do a manual install since 1.9.0 isn't out yet.

fpistm commented 4 years ago

@MCUdude In fact there is issue with the generic systemCoreClock config. It configures the clock assuming it is a 8Mhz for HSE but by default it is defined to 25MHz https://github.com/stm32duino/Arduino_Core_STM32/blob/master/system/STM32F4xx/system_stm32f4xx.c#L68

So it is misaligned when HSE is not bypass.

MCUdude commented 4 years ago

In fact there is issue with the generic systemCoreClock config. It configures the clock assuming it is a 8Mhz for HSE but by default it is defined to 25MHz https://github.com/stm32duino/Arduino_Core_STM32/blob/master/system/STM32F4xx/system_stm32f4xx.c#L68

So it is misaligned when HSE is not bypass.

But it would have worked if he used an extern 8 MHz crystal instead, and not touching the code?

fpistm commented 4 years ago

Yes but in this case this is not a bypass, I guess. Without bypass the clock config is not correct.

MCUdude commented 4 years ago

The board uses a crystal oscillator (that needs to be driven), not a clock (that drives itself). I will assume that since the MCU detects a crystal it will not enable bypass mode, and thus nothing will work since the expected clock frequency is 8 MHz and not 25.

What I do want to know is that if there's something that can be done to the pinout's clock config that somehow can detect what frequency is being applied, and adjust its setting based on this. Can this be done? Can the clock config functions on the generic pinouts be further improved to automatically support a wider range of external clocks/crystals without user interaction?

flatpedals commented 4 years ago

There is a dicussion about clock detection on 401: https://www.stm32duino.com/viewtopic.php?f=14&t=9&start=70 stevestrong also: https://www.stm32duino.com/viewtopic.php?f=24&t=52

TzOk83 commented 4 years ago

Haven't tried uploading yet, but I believe this should work: PILL_F411XX.zip

# BlackPill F411CE
GenF4.menu.pnum.BLACKPILL_F411CE=BlackPill F411CE
GenF4.menu.pnum.BLACKPILL_F411CE.upload.maximum_size=524288
GenF4.menu.pnum.BLACKPILL_F411CE.upload.maximum_data_size=131072
GenF4.menu.pnum.BLACKPILL_F411CE.build.board=BLACKPILL_F411CE
GenF4.menu.pnum.BLACKPILL_F411CE.build.product_line=STM32F411xE
GenF4.menu.pnum.BLACKPILL_F411CE.build.variant=PILL_F411XX
fpistm commented 4 years ago

In fact you want a "Clock framework". 😉 Anyway this is something, I will not be able to do. My guess, is that we cold not handle easily all possible value and they will be always complains about that. The generic should only implement a default clock config based on the HSI/MSI/CSI/LSI. As a generic variant the end user would have to use his own SystemClock_Config if he would customize it. The generic are mainly for those who want test quickly a custom board. A "commercial" board could then be added easily using the generic one.

As I explain in an other issue, several variants could now point to the generic one with some customization under board switch.

TzOk83 commented 4 years ago

With the attached BlackPill 411CE profile it uploads ok, and BLINK example works, but I can't make USB serial to work.

fpistm commented 4 years ago

@TzOk83 You have to ensure the USB clock is at 48 MHz

TzOk83 commented 4 years ago

Have no idea how to check this. The crystal is 25 MHz, and MCU in this version is supposed to run at 100 MHz, yet I took most of the files from PILL_401XX which runs at 84 MHz.

fpistm commented 4 years ago

The simpliest way is to use cube MX to generate a proper config.

TzOk83 commented 4 years ago

If someone is knows how to use, then probably it is... so if you have Cube MX and can use it, could you be so nice and do this?

flatpedals commented 4 years ago

@TzOk83 For USB serial to work check the USB CDC option as I mentioned. Also check the board schematic on WeAct github to see which pins they used for USB and make sure you are not using them for other stuff. I am successfully using the 411CE v1.3 with the edited platformio.ini and board def.

TzOk83 commented 4 years ago

I have checked it. When it is checked I have a problem with entering BOOT0 bootloader (CDC), usually I get USB device fault (but in normal mode virtual serial port is visible in the system). Previously I was using old "BluePill", so more or less I know how to set the options in Arduino. Could you upload here your modified 411CE profile / boards.ini?

https://github.com/jvitkauskas/weact/tree/master/STM32F411CEU6%20black%20board https://github.com/WeActTC/MiniF4-STM32F4x1/tree/master/STM32F411CEU6-Black-Board

flatpedals commented 4 years ago

In Arduino IDE I didn't edit anything, I am just using the 'Black pill 401CE' profile. See my first comment here, I posted the edited JSON and .ini only for PlatformIO. You could also try stevestrong's core: https://github.com/stevstrong/Arduino_STM32, he has done some specific work for the F4. My 411CE works with either core. I suggest uninstalling every related driver if you are on Win10 (show hidden devices in device manager and go clean).

fpistm commented 4 years ago

With this core, no specific driver are needed as we use the STMicroelectronics PID.

TzOk83 commented 4 years ago

I have roughly checked it and it seems to work now.

%LOCALAPPDATA%\Arduino15\packages\STM32\hardware\stm32\1.8.0: PILL_F411XX.zip

boards.txt:

# BlackPill F411CE
GenF4.menu.pnum.BLACKPILL_F411CE=BlackPill F411CE
GenF4.menu.pnum.BLACKPILL_F411CE.upload.maximum_size=524288
GenF4.menu.pnum.BLACKPILL_F411CE.upload.maximum_data_size=131072
GenF4.menu.pnum.BLACKPILL_F411CE.build.board=BLACKPILL_F411CE
GenF4.menu.pnum.BLACKPILL_F411CE.build.product_line=STM32F411xE
GenF4.menu.pnum.BLACKPILL_F411CE.build.variant=PILL_F411XX

I have done some further testing and Serial over USB works fine, I2C also, and I can define and use 100 kB array of data.

fpistm commented 4 years ago

@MCUdude In fact there is issue with the generic systemCoreClock config. It configures the clock assuming it is a 8Mhz for HSE but by default it is defined to 25MHz https://github.com/stm32duino/Arduino_Core_STM32/blob/master/system/STM32F4xx/system_stm32f4xx.c#L68

So it is misaligned when HSE is not bypass.

I'm wrong, the default is 25MHz as @MCUdude note in the https://github.com/stm32duino/Arduino_Core_STM32/blob/4e1c22561ae15c976a42699c97e08c53dbb3f4b7/system/STM32F4xx/system_stm32f4xx.c#L67-L69

fpistm commented 4 years ago

The clock config issue from the Generic F411Cx has been solved in #905. So I close this one. The BlackPil F4x1 support will be added reviewed to use the Generic F4x1 variant.

faelpinho commented 4 years ago

Hello. Do you know when will have available a new version from this lib? I need to use Generic F411CE. I've tried all tips here, but the upload to this board is not working yet. Thanks!

fpistm commented 4 years ago

I'm currently doing a full validation. It should be release in the coming weeks.

Onefabis commented 4 years ago

Serial steel doesn't work. If I try to open Arduino Monitor and it show message that 'Board COM3 is unavailable'. However, blink example works fine and my custom projects works well. But Encoder with custom library work ugly, something wrong, perhaps with Clock frequency, but I can't even debug this with Serial monitor, because it can't open properly.

fpistm commented 4 years ago

Hi @Onefabis without more details it is hard to help you. which core? What did you select in the menu? what is your board and clock config? ...

Onefabis commented 4 years ago

Hi, @fpistm, what did you mean about the core? Just got WeAct STM32F411CEU6 board. Didn't change anything, so I assume that it use 25MHz as a default clock speed. Here are settings in Arduino IDE (Stm32 Boards is v1.9.0) Clip2net_200708130727

fpistm commented 4 years ago

Well, for this boards clock is 25MHz. with your settings, the Serial instance mapped to Serial1 which is an HardwareSerial on USART1 (PA10/PA9) so you have to connect a FTDI or a real UART connector on those pins. If you want use the Serial overs USB then you have to select USB support: CDC (generic 'Serial' supersede U(S)ART).

For this kind of support please use the forum: https://www.stm32duino.com

samveen commented 4 years ago

@flatpedals

The STM32 HID seems to allow successful flashing but the MCU is never reset and the sketch doesn't run. I have to erase memory to get it out of that frozen state.

Can you tell me the method you used to erase all memory? I seem to be stuck in a similar situation: my Blackpill F411 only works in DFU mode, no matter what I try to program using dfu-util. Found it (very quickly via Google. Apologies :facepalm: ):

dfu-util -a 0 -d 0483:df11 -s 0x8000000:mass-erase:force -D Blink.bin -t 1024
Olareanu commented 3 years ago

build_flags = -D PIO_FRAMEWORK_ARDUINO_ENABLE_CDC -D USBCON -D USBD_VID=0x0483 -D USB_MANUFACTURER="Unknown" -D USB_PRODUCT=""BLACKPILL_411CE"" -D HAL_PCD_MODULE_ENABLED`

This worked for me (Serial trough USB port and blinking LED). It looks like only PIO_FRAMEWORK_ARDUINO_ENABLE_CDC and USBCON are needed. Using weAct 3.0 Black pill STM32F411CE with this PIO config:

[env:genericSTM32F411CE] platform = ststm32 board = blackpill_f411ce framework = arduino monitor_speed = 115200 upload_protocol = dfu build_flags = -D PIO_FRAMEWORK_ARDUINO_ENABLE_CDC -D USBCON

pitass82 commented 3 years ago

Hi Guys, Serial monitor hasn´t worked initially for me too, I made it work in Arduino IDE with FTDI and USART after I changed this: 1) editing code: serial begin in brackets 9600 means Serial.begin(9600); instead Serial.begin(); (open serial monitor w same baudrate 2) setting arduino IDE / Tools : CDC no generic serial STM32 Black Pill Serial Monitior works with editing serial begin in brackets 9600edit code plus CDC no generic serial

simply use(d) initial code from Examples / SD / readwrite and added baudrate 9600 in brackets and I also installed STM32CubeProgrammer software for all STM32 from https://www.st.com/content/st_com/en/products/development-tools/software-development-tools/stm32-software-development-tools/stm32-programmers/stm32cubeprog.html for Win64 | 2.8.0-- | -- I dont know if this might have had influence too. Hope it helps, Pete

miguelwon commented 2 years ago

Hi,

I just received a brand new BlackPill STM32F411CUE6 and I'm having a related problem. I trying to upload the blink example with Arduino IDE. I'm uploading through USB and using DFU mode. I'm able to upload only in case I set to None the USB support. The moment I set it to any of the CDC options, I get the Target not founderror.

I also have a BlackPill STM32F401C and it works fine.

fpistm commented 2 years ago

Hi @miguelwon,

Upload method and USB support menu has no link. While your board is properly reset in DFU bootloader mode upload should work as expected. I've tested several time and I have no issue.

  1. press Boot0 button then plus USB cable or press NRST
  2. press upload

The error Target not found is raised by the STM32CubeProgrammer if no DFU bootloader device is available.

miguelwon commented 2 years ago

Thanks. I know the steps. I use them when uploading to the BlackPill STM32F401C, as well as to the BlackPill STM32F411C when USB support is selected to None. But for this board (STM32F411C), if I set USB support to CDC (because I want to use Serial through USB), I'm not able to upload (with DFU mode).

fpistm commented 2 years ago

You should check the option bytes setting. Maybe the boot0 pin is not properly configured.