Go to file
Gareth McMullin 09c0fb5773 Build with libopencm3 as a submodule.
Fix incompatibilities with latest libopencm3.
2012-10-22 18:45:42 +13:00
driver Update Windows drivers to use new USB IDs. 2012-05-26 15:33:16 +12:00
flashstub stm32f4: Fixed chunk padding for flash programming. 2012-02-08 20:43:12 +13:00
hardware Added a Makefile for generation of some hardware outputs. 2012-04-12 18:47:30 +12:00
libopencm3@4e4496f70d Build with libopencm3 as a submodule. 2012-10-22 18:45:42 +13:00
scripts Fixed hexprog.py to work with current firmware 'g' packet. 2012-01-30 22:14:31 +13:00
src Build with libopencm3 as a submodule. 2012-10-22 18:45:42 +13:00
upgrade Corrected upgrade tool to use our new usb ids. 2012-07-27 21:59:03 +12:00
.gitignore Added .gitignore 2012-04-18 19:13:38 +12:00
.gitmodules Build with libopencm3 as a submodule. 2012-10-22 18:45:42 +13:00
COPYING Added README and COPYING 2011-02-07 11:01:10 +13:00
HACKING Updated HACKING file to new libftdi platform name. 2012-06-10 19:10:15 +12:00
README Add note that schematic is created in gschem. 2012-01-27 19:17:15 -05:00

README

=======================================
The Black Magic Debug Project -- README
=======================================

The Black Magic Debug Probe is gadget providing an in-application
debug capability for ARM Cortex-M3 and Cortex-M0 microcontrollers.  It
interfaces with the GDB, the GNU source level debugger over the USB
bus, and communicates with the target microcontroller over either a
JTAG or Serial Wire debug port.

Currently supported microcontrollers:

 - ST STM32 Family
 - TI/LMI Stellaris Family
 - NXP LPC11xx Family


Getting started
===============
The Black Magic Probe is available as a built-up product form Black
Sphere Technologies.  Contact <sales@blacksphere.co.nz> should
you wish to order one.  If you would like to work on the project see
the file HACKING for developer's info.

When connected via USB, the Black Magic probe will enumerate as a CDC-ACM
device which the OS should present as a tty device or serial port.  The
GDB remote debugging protocol is implemented over this virtual character
stream.  To connect your ARM GDB to the target device use the following
commands:

(gdb) target extended-remote /dev/ttyACM0
(gdb) mon jtag_scan
(gdb) attach 1

The command 'mon swdp_scan' may be used to use the Serial-Wire Debug Protocol
instead of JTAG to connect to the target.

Once attached, all the standard GDB commands may be used to start and control
the execution of the embedded application.


Project layout
==============
flashstub/ - Source code for flash programming stubs in target drivers.
hardware/ - Schematic (gschem) and PCB layout for the Black Magic Probe
scripts/ - Python scripts useful for programming devices.
src/ - Firmware source code for the Black Magic debug probe.