Skip to content

Latest commit

 

History

History
51 lines (29 loc) · 3.12 KB

README.md

File metadata and controls

51 lines (29 loc) · 3.12 KB

STM32DiscoveryVCP

This is a minimalistic project for the CooCox IDE which sets up a Virtual COM Port for the STM32F4xx Discovery Board. Running this code, the STM32 will appear as a COM port through which you can transmit and receive data. This project includes only the files necessary to compile for the STM32F4 as a VCP and uses the standard CooCox library files whenever possible.

The goals of this project are:

  • Provide a VCP project that works out-of-the box with CooCox
  • Provide a nice clean base from which to build other projects (because everything needs a VCP)

IDE and Compiler Setup

This project builds with the CooCox IDE - A great IDE for embedded ARM development - and the GNU Tools for Arm. Install the IDE and the GNU Tools, point the IDE to the GNU Tools bin directory, and start working on your ARMs!

Drivers and Utilities for the STM32F4xx

The STM32F4xx Discovery board has a built in ST-LINK/V2 in-circuit debugger/programmer. You can get drivers and utilities from that page.

You might also want the Virtual Com Port driver so you can talk to your STM32F4 once you load this project.

Building and Running the Code

  • Build: Load the project in CooCox IDE, click Build
  • Program: Click the "Program" button in the CooCox IDE
  • Test: Hook a USB Micro cable to the STM32 Discovery board. The device should show up as a virtual com port. If you connect to this port, the data you send will be echo'ed back and the green LED will flash with every character sent.

Debugging

One of the coolest things about CooCox is the in-circuit debugger via the ST-LINK works out of the box. That means you just click the little bug icon, wait a few seconds, and you've got breakpoints in a live embedded device! You can step through the code, see variables, change things, etc. Way Awesome!

If that doesn't cut it for you, you can also look at the blinky LED's. If you load this project on the board and everything's running correctly, the orange LED should be blinking at close to 1Hz. If something went wrong with the initialization, or if there was a USB exception, you'll see the four LED's blinking in a rapid clockwise order (it's fun to watch!). If there's no LED's blinking, something went really wrong and the code didn't even get to the GPIO Init section...

Future Improvements

I'm trying to keep this repo as clean and to-the-point as possible so I have a nice starting point to build my cooler projects from. But making this easier for others to use would be nice too, so maybe I'll setup a Makefile build setup.

Special Thanks to the folks who wrote these Useful Pages