blue-pill: fix linker scripts and asm led turnon
This commit is contained in:
parent
ca7eaec903
commit
943e2bfa93
|
@ -0,0 +1,70 @@
|
||||||
|
# configurables
|
||||||
|
OBJS :=
|
||||||
|
TARGET := blink
|
||||||
|
OBJS += $(TARGET).o
|
||||||
|
|
||||||
|
# targets
|
||||||
|
ELF := $(TARGET).elf
|
||||||
|
BIN := $(TARGET).bin
|
||||||
|
|
||||||
|
# toolchain setup
|
||||||
|
ARMTC := arm-none-eabi
|
||||||
|
CC := $(ARMTC)-gcc
|
||||||
|
LD := $(ARMTC)-gcc
|
||||||
|
AS := $(ARMTC)-as
|
||||||
|
ARMSIZE := $(ARMTC)-size
|
||||||
|
OBJCOPY := $(ARMTC)-objcopy
|
||||||
|
PAGER ?= less
|
||||||
|
|
||||||
|
# compiler options
|
||||||
|
CPUFLAGS := -mcpu=cortex-m3 -mthumb -std=c99
|
||||||
|
CFLAGS := -Wall -Wextra -Os -MD $(CPUFLAGS) -g
|
||||||
|
LDFLAGS := $(CPUFLAGS) -nostartfiles -Wl,-T,bluepill.ld
|
||||||
|
LDLIBS := -lc -lnosys
|
||||||
|
|
||||||
|
# programmer options
|
||||||
|
STARTMEM := 0x8000000
|
||||||
|
|
||||||
|
# targets
|
||||||
|
|
||||||
|
.PHONY: all
|
||||||
|
all: $(BIN)
|
||||||
|
|
||||||
|
$(ELF): $(OBJS)
|
||||||
|
$(CC) $(LDFLAGS) -o $@ $(OBJS) $(LDLIBS)
|
||||||
|
$(ARMSIZE) $@
|
||||||
|
|
||||||
|
.PHONY: strip
|
||||||
|
strip: $(ELF)
|
||||||
|
$(ARMTC)-strip $(ELF)
|
||||||
|
$(ARMSIZE) $(ELF)
|
||||||
|
|
||||||
|
$(BIN): $(ELF)
|
||||||
|
$(OBJCOPY) -O binary $< $@
|
||||||
|
|
||||||
|
.PHONY: flash
|
||||||
|
flash: $(BIN)
|
||||||
|
st-flash write $(BIN) $(STARTMEM)
|
||||||
|
|
||||||
|
.PHONY: erase
|
||||||
|
erase:
|
||||||
|
st-flash erase
|
||||||
|
|
||||||
|
.PHONY: reset
|
||||||
|
reset:
|
||||||
|
st-flash reset
|
||||||
|
|
||||||
|
.PHONY: install
|
||||||
|
install: erase flash reset
|
||||||
|
|
||||||
|
.PHONY: clean
|
||||||
|
clean:
|
||||||
|
rm -f *.o *.bin *.elf *.d *.map
|
||||||
|
|
||||||
|
.PHONY: disass
|
||||||
|
disass: $(ELF)
|
||||||
|
$(ARMTC)-objdump -D $(ELF) | $(PAGER)
|
||||||
|
|
||||||
|
.PHONY: dump
|
||||||
|
dump: $(ELF)
|
||||||
|
$(ARMTC)-objcopy -D $(ELF) > $(TARGET).dump
|
|
@ -0,0 +1,43 @@
|
||||||
|
.syntax unified
|
||||||
|
.cpu cortex-m3
|
||||||
|
.thumb
|
||||||
|
|
||||||
|
.section .text
|
||||||
|
.global vectors
|
||||||
|
vectors:
|
||||||
|
.align 2
|
||||||
|
.word 0
|
||||||
|
.word _start
|
||||||
|
|
||||||
|
.thumb_func
|
||||||
|
.global _start
|
||||||
|
_start:
|
||||||
|
/* enable port C clock */
|
||||||
|
ldr r0, =0x40021000
|
||||||
|
ldr r1, [r0, #0x18]
|
||||||
|
mov r2, #5
|
||||||
|
orr r1, r2
|
||||||
|
str r1, [r0, #0x18]
|
||||||
|
|
||||||
|
/*
|
||||||
|
* enable output mode at a max of 2 MHz.
|
||||||
|
* note that the default is a general purpose output push-pull,
|
||||||
|
* which is what it should be.
|
||||||
|
*/
|
||||||
|
ldr r0, =0x40011000
|
||||||
|
ldr r1, [r0, #0x04]
|
||||||
|
mov r2, #0x02
|
||||||
|
lsl r2, #0x14
|
||||||
|
orr r1, r2
|
||||||
|
str r1, [r0, #0x04]
|
||||||
|
|
||||||
|
/* write LED pin (PC13) */
|
||||||
|
ldr r0, =0x40011000
|
||||||
|
ldr r1, [r0, #0x10]
|
||||||
|
mov r2, #0x01
|
||||||
|
lsl r2, #0x0d
|
||||||
|
lsl r2, #0x10
|
||||||
|
orr r1, r2
|
||||||
|
str r1, [r0, #0x10]
|
||||||
|
|
||||||
|
hang: bl .
|
|
@ -0,0 +1,18 @@
|
||||||
|
MEMORY
|
||||||
|
{
|
||||||
|
flash (rx) : ORIGIN = 0x08000000, LENGTH = 64K
|
||||||
|
sram (rwx) : ORIGIN = 0x20000000, LENGTH = 20K
|
||||||
|
}
|
||||||
|
|
||||||
|
EXTERN(vectors);
|
||||||
|
ENTRY(_start);
|
||||||
|
|
||||||
|
SECTIONS
|
||||||
|
{
|
||||||
|
.text : {
|
||||||
|
*(.vectors*)
|
||||||
|
*(.text*)
|
||||||
|
. = ALIGN(4);
|
||||||
|
} > flash
|
||||||
|
.bss : { *(.bss*) } > sram
|
||||||
|
}
|
|
@ -9,6 +9,8 @@
|
||||||
.cpu cortex-m3
|
.cpu cortex-m3
|
||||||
.thumb
|
.thumb
|
||||||
|
|
||||||
|
.section .text
|
||||||
|
.global vectors
|
||||||
vectors:
|
vectors:
|
||||||
.align 2
|
.align 2
|
||||||
.long 0x20005000 /* stack pointer points to top of SRAM */
|
.long 0x20005000 /* stack pointer points to top of SRAM */
|
||||||
|
|
|
@ -1,11 +1,18 @@
|
||||||
MEMORY
|
MEMORY
|
||||||
{
|
{
|
||||||
flash (rx) : ORIGIN = 0x00000000, LENGTH = 128K
|
flash (rx) : ORIGIN = 0x08000000, LENGTH = 64K
|
||||||
sram (rwx) : ORIGIN = 0x20000000, LENGTH = 20K
|
sram (rwx) : ORIGIN = 0x20000000, LENGTH = 20K
|
||||||
}
|
}
|
||||||
|
|
||||||
|
EXTERN(vectors);
|
||||||
|
ENTRY(reset_handler);
|
||||||
|
|
||||||
SECTIONS
|
SECTIONS
|
||||||
{
|
{
|
||||||
.text : { *(.text*) } > flash
|
.text : {
|
||||||
|
*(.vectors*)
|
||||||
|
*(.text*)
|
||||||
|
. = ALIGN(4);
|
||||||
|
} > flash
|
||||||
.bss : { *(.bss*) } > sram
|
.bss : { *(.bss*) } > sram
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue