mirror of
git://projects.qi-hardware.com/ben-wpan.git
synced 2025-01-11 07:20:15 +02:00
fd91546c59
What caused the error that looked like a problem with the functional descriptor was in fact the boot loader resetting between the bus scan and retrieval of the descriptor.
158 lines
4.0 KiB
Makefile
158 lines
4.0 KiB
Makefile
#
|
|
# Makefile - Makefile of the ATUSB firmware
|
|
#
|
|
# Written 2010-2011 by Werner Almesberger
|
|
# Copyright 2010-2011 by Werner Almesberger
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
|
|
SHELL = /bin/bash
|
|
|
|
NAME = atusb
|
|
|
|
CFLAGS = -g -mmcu=$(CHIP) -DBOOT_ADDR=$(BOOT_ADDR) \
|
|
-Wall -Wextra -Wshadow -Werror -Wno-unused-parameter \
|
|
-Wmissing-prototypes -Wmissing-declarations -Wstrict-prototypes
|
|
|
|
CHIP=atmega32u2
|
|
HOST=jlime
|
|
BOOT_ADDR=0x7000
|
|
|
|
AVR_PREFIX = $(BIN_PATH) avr-
|
|
CC = $(AVR_PREFIX)gcc
|
|
OBJCOPY = $(AVR_PREFIX)objcopy
|
|
#OBJDUMP = $(AVR_PREFIX)objdump
|
|
SIZE = $(AVR_PREFIX)size
|
|
|
|
USB_OBJS = usb.o atu2.o
|
|
OBJS = atusb.o board.o spi.o descr.o ep0.o $(USB_OBJS)
|
|
BOOT_OBJS = boot.o board.o spi.o flash.o dfu.o $(USB_OBJS)
|
|
|
|
vpath %.c usb/
|
|
|
|
CFLAGS += -Iinclude -Iusb
|
|
|
|
# ----- Verbosity control -----------------------------------------------------
|
|
|
|
CC_normal := $(CC)
|
|
BUILD_normal :=
|
|
DEPEND_normal := $(CPP) $(CFLAGS) -MM -MG
|
|
|
|
CC_quiet = @echo " CC " $@ && $(CC_normal)
|
|
BUILD_quiet = @echo " BUILD " $@ && $(BUILD_normal)
|
|
DEPEND_quiet = @$(DEPEND_normal)
|
|
|
|
ifeq ($(V),1)
|
|
CC = $(CC_normal)
|
|
BUILD = $(BUILD_normal)
|
|
DEPEND = $(DEPEND_normal)
|
|
else
|
|
CC = $(CC_quiet)
|
|
BUILD = $(BUILD_quiet)
|
|
DEPEND = $(DEPEND_quiet)
|
|
endif
|
|
|
|
# ----- Rules -----------------------------------------------------------------
|
|
|
|
.PHONY: all clean upload prog dfu version.c
|
|
.PHONY: prog-app prog-read on off reset
|
|
|
|
all: $(NAME).bin boot.hex
|
|
|
|
$(NAME).elf: $(OBJS)
|
|
$(MAKE) version.o
|
|
$(CC) $(CFLAGS) -o $@ $(OBJS) version.o
|
|
|
|
boot.elf: $(BOOT_OBJS)
|
|
$(CC) $(CFLAGS) -o $@ $(BOOT_OBJS) \
|
|
-Wl,--section-start=.text=$(BOOT_ADDR)
|
|
|
|
%.bin: %.elf
|
|
$(BUILD) $(OBJCOPY) -j .text -j .data -O binary $< $@
|
|
@echo "build #`cat .version`, `ls -l $@`"
|
|
|
|
%.hex: %.elf
|
|
$(BUILD) $(OBJCOPY) -j .text -j .data -O ihex $< $@
|
|
$(SIZE) $@
|
|
|
|
# ----- Cleanup ---------------------------------------------------------------
|
|
|
|
clean:
|
|
rm -f $(NAME).bin $(NAME).elf
|
|
rm -f $(OBJS) $(OBJS:.o=.d)
|
|
rm -f boot.hex boot.elf
|
|
rm -f $(BOOT_OBJS) $(BOOT_OBJS:.o=.d)
|
|
rm -f version.c version.d version.o
|
|
|
|
# ----- Build version ---------------------------------------------------------
|
|
|
|
version.c:
|
|
@if [ -f .version ]; then \
|
|
v=`cat .version`; \
|
|
expr $$v + 1 >.version; \
|
|
else \
|
|
echo 0 >.version; \
|
|
fi
|
|
@[ -s .version ] || echo 0 >.version
|
|
@echo '/* MACHINE-GENERATED. DO NOT EDIT ! */' >version.c
|
|
@echo '#include "version.h"' >>version.c
|
|
@echo "const char *build_date = \"`date`\";" >>version.c
|
|
@echo "const uint16_t build_number = `cat .version`;" \
|
|
>>version.c
|
|
|
|
# ----- Dependencies ----------------------------------------------------------
|
|
|
|
%.o: %.c
|
|
$(CC) $(CFLAGS) -Os -c $<
|
|
$(DEPEND) $< | \
|
|
sed -e \
|
|
'/^\(.*:\)\? */{p;s///;s/ *\\\?$$/ /;s/ */:\n/g;H;}' \
|
|
-e '$${g;p;}' -e d >$*.d; \
|
|
[ "$${PIPESTATUS[*]}" = "0 0" ] || { rm -f $*.d; exit 1; }
|
|
|
|
-include $(OBJS:.o=.d)
|
|
|
|
# ----- Programming and device control ----------------------------------------
|
|
|
|
upload: $(NAME).bin boot.hex
|
|
scp $(NAME).bin boot.hex $(HOST):
|
|
|
|
# lfuse: external clock, slow start-up
|
|
# hfuse: 4 kB boot loader, reset into boot loader
|
|
# lock: allow everything but SPM to the boot loader
|
|
# Note: when trying to program 0xef, we get back 0x2f, failing
|
|
# verification. So we just program 0x2f.
|
|
|
|
prog-app:
|
|
ssh $(HOST) avrdude -F -p $(CHIP) -c nanonote_atusb -e \
|
|
-U flash:w:atusb.bin:r \
|
|
-U lfuse:w:0x60:m
|
|
|
|
prog:
|
|
ssh $(HOST) avrdude -F -p $(CHIP) -c nanonote_atusb -e \
|
|
-U flash:w:boot.hex:i \
|
|
-U lfuse:w:0x60:m \
|
|
-U hfuse:w:0xd8:m \
|
|
-U lock:w:0x2f:m
|
|
|
|
prog-read:
|
|
ssh $(HOST) avrdude -F -p $(CHIP) -c nanonote_atusb \
|
|
-U flash:r:mcu.bin:r
|
|
|
|
dfu: $(NAME).bin
|
|
dfu-util -d 20b7:1540 -D $(NAME).bin
|
|
|
|
on:
|
|
ssh $(HOST) poke 0x10010318 4
|
|
|
|
off:
|
|
ssh $(HOST) poke 0x10010314 4
|
|
|
|
reset:
|
|
ssh $(HOST) poke 0x10010318 2048
|
|
ssh $(HOST) poke 0x10010314 2048
|