-
Notifications
You must be signed in to change notification settings - Fork 90
/
make.sh
executable file
·95 lines (82 loc) · 4.49 KB
/
make.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#!/bin/sh
# avr-gcc++ path
# Replace by location of your avr-gcc compiler if different
BINPATH="/usr/bin"
INCPATH="./source"
SOURCEPATH="./source"
BUILDPATH="./build"
# If you have file not found errors, try replacing '.' by '$PWD' in the previous paths, e.g.
# SOURCEPATH="$PWD/source"
OPTFLAGS="-Os -fno-jump-tables -fno-gcse -flto -ffunction-sections -fdata-sections -fpack-struct -fshort-enums -mrelax"
CSTDFLAGS="-funsigned-char -funsigned-bitfields -std=gnu++11"
# Select host device
#
# Supported classic AVR: atmega16, atmega88/168/328p, atmega1280/2560, probably others
# Supported Logic Green devices: LGT8F328P/D, however, atmega328p must be set as target
# Supported AVR-0/1 devices (aka avrxmega3 architecture on gcc): all that have at least 512 KB RAM
#
TARGETMCU=atmega328p
# configuration macros
#
# NDEBUG -> if defined, disable debug output
#
# F_CPU=value -> declares at which speed the host device is running (defaults to 16000000, 16MHz)
#
# UPDI_BAUD=value -> sets UPDI baud rate. Maximum is 225000 (225 kbaud, default value). Minimum is F_CPU/200
#
# ARDUINO_AVR_LARDU_328E -> if defined, host device is a Logic Green LGT8F328P/D
#
# UPDI_IO_TYPE=value -> Selects bitbang UART for interfacing with the UPDI target device. Possible values are 1 and 2.
# Type 1 is deprecated, so use type 2 (default).
#
# UPDI_PORT=port_letter and UPDI_PIN=pin_number -> Select port and pin for UPDI interface to target.
# If using UPDI_IO_TYPE=1, these must be set to the OC0A timer output pin.
# If using UPDI_IO_TYPE=2, these can be any free I/O pin.
# If the target is the Mega328P, defaults to the OC0A pin (PD6). See "sys.h" file for more details.
#
# HOST_USART=USARTx -> Select USART to be used for serial communication with the host PC, for host devices that
# have more than one USART peripheral (tiny AVR-0/1 and mega AVR-0 only). Defaults to USART0.
#
# HOST_TX_PORT=port_letter and HOST_TX_PIN=pin_number -> Must correspond to port and pin where the Tx signal of HOST_USART
# is present (tiny AVR-0/1 and mega AVR-0 only). Defaults to PB2, which is the Tx pin for USART0 on many tiny AVR-0/1 chips.
#
# DISABLE_HOST_TIMEOUT and DISABLE_TARGET_TIMEOUT -> disable timeout counter on host and/or target links
# IMPORTANT NOTE: To use terminal mode, DISABLE_HOST_TIMEOUT must be defined (default for this makefile)
#
# default:
# DEFINES="-DNDEBUG -DUPDI_BAUD=225000U -DF_CPU=16000000 -DUPDI_IO_TYPE=2 -DDISABLE_HOST_TIMEOUT"
DEFINES="-DNDEBUG -DUPDI_BAUD=225000U -DF_CPU=16000000 -DUPDI_IO_TYPE=2 -DDISABLE_HOST_TIMEOUT"
##
## select AVRJTAGICE v2.0 as target (override upper)
##
#TARGETMCU=atmega16
#DEFINES="-DNDEBUG -DUPDI_BAUD=120000U -DF_CPU=7372800 -DLED_PORT=B -DLED_PIN=3 -DUPDI_PORT=D -DUPDI_PIN=2 -DUPDI_IO_TYPE=2 -DDISABLE_HOST_TIMEOUT"
echo Compiling for $TARGETMCU ...
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o UPDI_lo_lvl.o $SOURCEPATH/UPDI_lo_lvl.cpp
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o UPDI_hi_lvl.o $SOURCEPATH/UPDI_hi_lvl.cpp
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o jtag2updi.o $SOURCEPATH/jtag2updi.cpp
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o JICE_io.o $SOURCEPATH/JICE_io.cpp
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o JTAG2.o $SOURCEPATH/JTAG2.cpp
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o updi_io_soft.o $SOURCEPATH/updi_io_soft.cpp
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o updi_io.o $SOURCEPATH/updi_io.cpp
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o crc16.o $SOURCEPATH/crc16.cpp
$BINPATH/avr-g++ $DEFINES -c -I$INCPATH $OPTFLAGS $CSTDFLAGS -Wall -mmcu=$TARGETMCU -o sys.o $SOURCEPATH/sys.cpp
echo Linking...
if [ ! -d $BUILDPATH ]
then
mkdir $BUILDPATH
fi
set OPTFLAGS="-Os -flto -mrelax"
$BINPATH/avr-g++ -o $BUILDPATH/JTAG2UPDI.elf \
jtag2updi.o JTAG2.o JICE_io.o UPDI_lo_lvl.o \
UPDI_hi_lvl.o updi_io.o updi_io_soft.o crc16.o sys.o \
-Wl,-Map="$BUILDPATH/STK2UPDI.map" -Wl,-lm \
-Wl,--start-group -Wl,--end-group -Wl,--gc-sections \
-mmcu=$TARGETMCU $OPTFLAGS
echo Cleaning up...
rm -rf *.o
cd $BUILDPATH
echo Creating HEX file...
$BINPATH/avr-objcopy -O ihex "JTAG2UPDI.elf" "JTAG2UPDI.hex"
echo Creating LSS file...
$BINPATH/avr-objdump -h -S "JTAG2UPDI.elf" > "JTAG2UPDI.lss"