merged/modified/etc.
1. Merge remote-tracking branch 'refs/remotes/sudar/master' Conflicts: .gitignore arduino-mk/Arduino.mk 2. reflected the advise from jaysonlarose. 3. I guess raw_eeprom should require `reset' on leonardo... I'm not sure.
This commit is contained in:
commit
0b2877cfed
8 changed files with 633 additions and 219 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -1,3 +1,5 @@
|
||||||
*.o
|
*.o
|
||||||
build-cli
|
build-cli
|
||||||
*~
|
*~
|
||||||
|
/.project
|
||||||
|
|
||||||
|
|
140
README.md
140
README.md
|
@ -1,30 +1,17 @@
|
||||||
# A Makefile for Arduino Sketches
|
# A Makefile for Arduino Sketches
|
||||||
|
|
||||||
This is a very simple Makefile which knows how to build Arduino sketches.
|
This is a very simple Makefile which knows how to build Arduino sketches. It defines the entire workflows for compiling code, flashing it to Arduino and even communicating through Serial monitor. You don't need to change anything in the Arduino sketches.
|
||||||
|
|
||||||
Until March 2012, this was simply posted on my website where you can
|
If you're using Debian or Ubuntu, you can find this in the `arduino-mk` package.
|
||||||
still find [what
|
|
||||||
documentation](http://mjo.tc/atelier/2009/02/arduino-cli.html
|
|
||||||
"Documentation") exists.
|
|
||||||
|
|
||||||
If you're using Debian or Ubuntu, you can find this in the
|
## Credits
|
||||||
arduino-mk package.
|
|
||||||
|
|
||||||
# Important Changes, 2012-04-29
|
This makefile was originally created by [Martin Oldfield](http://mjo.tc/atelier/2009/02/arduino-cli.html) and he maintained it till v0.10.2.
|
||||||
|
From May 2013, it is maintained by [Sudar](http://hardwarefun.com)
|
||||||
|
|
||||||
I've rejigged the path calculations so that:
|
## Usage
|
||||||
|
|
||||||
1. Few, if any paths, need to specified in the project specific Makefiles.
|
Download a copy of this repo some where in your system.
|
||||||
|
|
||||||
1. The paths can be grabber from the environment e.g. set up in a user's .bashrc.
|
|
||||||
|
|
||||||
1. It should be easier to move between e.g. Mac and Linux.
|
|
||||||
|
|
||||||
I'm indebted to Christopher Peplin for making me think about this, and indeed for
|
|
||||||
contributing code which did similar things in different ways.
|
|
||||||
|
|
||||||
The upshot of all this is that you'll need to set up some variables if you want
|
|
||||||
this to work:
|
|
||||||
|
|
||||||
On the Mac you might want to set:
|
On the Mac you might want to set:
|
||||||
|
|
||||||
|
@ -38,12 +25,12 @@ On Linux, you might prefer:
|
||||||
AVR_TOOLS_DIR = /usr
|
AVR_TOOLS_DIR = /usr
|
||||||
|
|
||||||
The Makefile also delegates resetting the board to a short Perl program.
|
The Makefile also delegates resetting the board to a short Perl program.
|
||||||
You'll need to install Device::SerialPort to use it though. You'll also
|
You'll need to install `Device::SerialPort` to use it though. You'll also
|
||||||
need the YAML library to run ard-parse-boards.
|
need the `YAML` library to run ard-parse-boards.
|
||||||
|
|
||||||
On Debian or Ubuntu:
|
On Debian or Ubuntu:
|
||||||
|
|
||||||
apt-get install libdevice-serial-perl
|
apt-get install libdevice-serialport-perl
|
||||||
apt-get install libyaml-perl
|
apt-get install libyaml-perl
|
||||||
|
|
||||||
On Fedora:
|
On Fedora:
|
||||||
|
@ -51,6 +38,13 @@ On Fedora:
|
||||||
yum install perl-Device-SerialPort
|
yum install perl-Device-SerialPort
|
||||||
yum install perl-YAML
|
yum install perl-YAML
|
||||||
|
|
||||||
|
On Mac using MacPorts:
|
||||||
|
|
||||||
|
sudo port install p5-device-serialport
|
||||||
|
sudo port install p5-YAML
|
||||||
|
|
||||||
|
and use /opt/local/bin/perl5 instead of /usr/bin/perl
|
||||||
|
|
||||||
On other systems:
|
On other systems:
|
||||||
|
|
||||||
cpanm Device::SerialPort
|
cpanm Device::SerialPort
|
||||||
|
@ -62,3 +56,103 @@ In order to use Arduino libraries installed in the user's sketchbook folder (the
|
||||||
standard location for custom libraries when using the Arduino IDE), you need to
|
standard location for custom libraries when using the Arduino IDE), you need to
|
||||||
set the `ARDUINO_SKETCHBOOK` variable to point to this directory. By default it
|
set the `ARDUINO_SKETCHBOOK` variable to point to this directory. By default it
|
||||||
is set to `$HOME/sketchbook`.
|
is set to `$HOME/sketchbook`.
|
||||||
|
|
||||||
|
## Changelog
|
||||||
|
|
||||||
|
The following is the rough list of changes that went into different versions. I tried to give credit whenever possible. If I have missed anyone, kindly add it to the list.
|
||||||
|
|
||||||
|
### 0.10.2 15.xii.2012 Sudar
|
||||||
|
- Added sketch size verification. (https://github.com/fornellas)
|
||||||
|
- Show original line number for error messages (https://github.com/WizenedEE)
|
||||||
|
- Removed -w from CPPFLAGS to show warnings (https://github.com/gaftech)
|
||||||
|
- Changed shebang to use /usr/bin/env (https://github.com/anm)
|
||||||
|
- set USB_VID and USB_PID only for leonardo boards(https://github.com/alohr)
|
||||||
|
- Updated Readme (https://github.com/fr0sty1/)
|
||||||
|
|
||||||
|
### 0.10.1 15.xii.2012 Sudar
|
||||||
|
- Merged all changes from Upstream and the following changes from https://github.com/rpavlik
|
||||||
|
- Allow passing extra flags
|
||||||
|
- Make listing files more useful
|
||||||
|
- Add knowledge of device-specific assembler
|
||||||
|
- Use variables instead of hardcoded commands
|
||||||
|
- Make disasm more helpful
|
||||||
|
- Change .sym output
|
||||||
|
- Provide symbol_sizes and generated_assembly targets.
|
||||||
|
- Be able to silence configuration output
|
||||||
|
- Make everybody depend on the makefile, in case cflags are changed, etc.
|
||||||
|
- Make the makefile error if the arduino port is not present.
|
||||||
|
|
||||||
|
### 0.10 17.ix.12 M J Oldfield
|
||||||
|
- Merged all changes from Upstream
|
||||||
|
|
||||||
|
### 0.9.3.2 10.ix.2012 Sudar
|
||||||
|
- Fixed a typo in README. Issue reported at upstream (https://github.com/mjoldfield/Arduino-Makefile/issues/21)
|
||||||
|
|
||||||
|
### 0.9.3.1 18.viii.2012 jeffkowalski
|
||||||
|
|
||||||
|
- Autodetect ARDUINO_LIBS from includes in LOCAL_SRCS
|
||||||
|
- Autodetect ARDUINO_SKETCHBOOK from file set by Arduino IDE
|
||||||
|
- Autodetect ARDMK_DIR based on location of this file
|
||||||
|
- Added support for utility directory within SYS and USER libraries
|
||||||
|
|
||||||
|
### 0.9.3 13.vi.2012
|
||||||
|
|
||||||
|
- Auto detect ARDUINO_DIR, Arduino version (https://github.com/rpavlik/)
|
||||||
|
- Categorize libs into user and system (https://github.com/rpavlik/)
|
||||||
|
- Dump size at the end of the build (https://github.com/rpavlik/)
|
||||||
|
- Lots and lots of improvements (https://github.com/rpavlik/)
|
||||||
|
- Changed bytes option for the head shell command, so that it works in Mac as well
|
||||||
|
- Auto detect Serial Baud rate from sketch if possible
|
||||||
|
|
||||||
|
### 0.9.2 06.vi.2012
|
||||||
|
|
||||||
|
- Allow user to choose source files (LOCAL_*_SRCS flags) (https://github.com/Gaftech)
|
||||||
|
- Modified "make size" behavior: using --mcu option and targeting .elf file instead of .hex file.(https://github.com/Gaftech)
|
||||||
|
|
||||||
|
### 0.9.1 06.vi.2012
|
||||||
|
|
||||||
|
- Corrected the ubuntu package names
|
||||||
|
- Prevent the *file-not-found* error if the depends.mk file is not needed
|
||||||
|
- Delete the build-cli folder as well while doing make clean
|
||||||
|
- Added support for compiling .pde files in Arduino 1.0 environment
|
||||||
|
- Replaced = with += in CPPFLAGS assignment so that we can set CPPFLAGS per sketch if needed
|
||||||
|
- Changed AVRDUDE_CONF so it can be defined in per-project makefile (https://github.com/WizenedEE)
|
||||||
|
- Cleaner way to delete the build-cli directory when make clean is invoked
|
||||||
|
- The package name in Debian and Ubuntu is arduino-mk (https://github.com/maqifrnswa)
|
||||||
|
|
||||||
|
### 2012-02-12, version 0.8
|
||||||
|
- Patches for version 1.0 of the Arduino IDE. Older versions might still work, but I’ve not tested it.
|
||||||
|
- A change to the build process: rather than link all the system objects directly into the executable, bundle them in a library first. This should make the final executable smaller.
|
||||||
|
- If TARGET isn’t explicitly set, default to the current directory name. Thanks to Daniele Vergini for this patch.
|
||||||
|
- Add support for .c files in system libraries: Dirk-Willem van Gulik and Evan Goldenberg both reported this and provided patches in the same spirit.
|
||||||
|
- Added a size target as suggested by Alex Satrapa.
|
||||||
|
|
||||||
|
### Unreleased, version 0.7
|
||||||
|
- Added -lm to the linker options, and -F to stty.
|
||||||
|
|
||||||
|
### 2011-06-23, version 0.6
|
||||||
|
- Added ard-parse-boards. Mark Sproul suggested doing something like this ages ago, but I’ve only recently looked at it in detail.
|
||||||
|
- Fabien Le Lez reported that one needs to link with -lc to avoid [linker errors](http://forum.arduino.cc/index.php/topic,40215.0.html).
|
||||||
|
|
||||||
|
### 2011-06-23, version 0.5
|
||||||
|
- Imported changes from Debian/Ubuntu, which incorporate a patch from Stefan Tomanek so that libraries would be compiled too.
|
||||||
|
|
||||||
|
Note: Many other people sent me similar patches, but I didn’t get around to using them. In the end, I took the patch from Debian and Ubuntu: there seems merit in not forking the code and using a tested version. So, thanks and apologies to Nick Andrew, Leandro Coletto Biazon, Thibaud Chupin, Craig Hollabaugh, Johannes H. Jensen, Fabien Le Lez, Craig Leres, and Mark Sproul.
|
||||||
|
|
||||||
|
### 2010-05-24, version 0.4
|
||||||
|
Tweaked rules for the reset target on Philip Hands’ advice.
|
||||||
|
|
||||||
|
### 2010-05-21, version 0.3
|
||||||
|
- Tidied up the licensing, making it clear that it’s released under LGPL 2.1.
|
||||||
|
- [Philip Hands](http://hands.com/~phil/) sent me some code to reset the Arduino by dropping DTR for 100ms, and I added it.
|
||||||
|
- Tweaked the Makefile to handle version 0018 of the Arduino software which now includes main.cpp. Accordingly we don’t need to—and indeed must not—add main.cxx to the .pde sketch file. The paths seem to have changed a bit too.
|
||||||
|
|
||||||
|
## Know Issues
|
||||||
|
- Because of the way the makefile is structured, the configuration parameters gets printed twice.
|
||||||
|
- Doesn't work with Leonardo yet.
|
||||||
|
- More todo's at https://github.com/sudar/Arduino-Makefile/issues/
|
||||||
|
|
||||||
|
## Similar works
|
||||||
|
- It's not a derivative of this, but Alan Burlison has written a [similar thing](http://bleaklow.com/2010/06/04/a_makefile_for_arduino_sketches.html).
|
||||||
|
- Alan's Makefile was used in a [Pragmatic Programmer's article](http://pragprog.com/magazines/2011-04/advanced-arduino-hacking).
|
||||||
|
- Rei Vilo wrote to tell me that he's using the Makefile ina Xcode 4 template called [embedXcode](http://embedxcode.weebly.com/). Apparently it supports many platforms and boards, including AVR-based Arduino, AVR-based Wiring, PIC32-based chipKIT, MSP430-based LaunchPad and ARM3-based Maple.
|
||||||
|
|
|
@ -3,6 +3,9 @@
|
||||||
# Arduino command line tools Makefile
|
# Arduino command line tools Makefile
|
||||||
# System part (i.e. project independent)
|
# System part (i.e. project independent)
|
||||||
#
|
#
|
||||||
|
# Copyright (C) 2012 Sudar <http://sudarmuthu.com>, based on
|
||||||
|
# - M J Oldfield work: https://github.com/mjoldfield/Arduino-Makefile
|
||||||
|
#
|
||||||
# Copyright (C) 2010,2011,2012 Martin Oldfield <m@mjo.tc>, based on
|
# Copyright (C) 2010,2011,2012 Martin Oldfield <m@mjo.tc>, based on
|
||||||
# work that is copyright Nicholas Zambetti, David A. Mellis & Hernando
|
# work that is copyright Nicholas Zambetti, David A. Mellis & Hernando
|
||||||
# Barragan.
|
# Barragan.
|
||||||
|
@ -78,6 +81,41 @@
|
||||||
# clarity and better error handling (ex
|
# clarity and better error handling (ex
|
||||||
# Daniele Vergini)
|
# Daniele Vergini)
|
||||||
#
|
#
|
||||||
|
# 0.9.1 06.vi.2012 Sudar
|
||||||
|
# - Corrected the ubuntu package names
|
||||||
|
# - Prevent the *file-not-found* error if the depends.mk file is not needed
|
||||||
|
# - Delete the build-cli folder as well while doing make clean
|
||||||
|
# - Added support for compiling .pde files in Arduino 1.0 environment
|
||||||
|
# - Replaced = with += in CPPFLAGS assignment so that we can set CPPFLAGS per sketch if needed
|
||||||
|
# - Changed AVRDUDE_CONF so it can be defined in per-project makefile (https://github.com/WizenedEE)
|
||||||
|
# - Cleaner way to delete the build-cli directory when make clean is invoked
|
||||||
|
# - The package name in Debian and Ubuntu is arduino-mk (https://github.com/maqifrnswa)
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# 0.9.2 06.vi.2012 Sudar
|
||||||
|
# - Allow user to choose source files (LOCAL_*_SRCS flags) (https://github.com/Gaftech)
|
||||||
|
# - Modified 'make size' behavior: using --mcu option and targeting .elf file instead of .hex file.(https://github.com/Gaftech)
|
||||||
|
#
|
||||||
|
# 0.9.3 13.vi.2012 Sudar
|
||||||
|
# - Autodetect ARDUINO_DIR, Arduino version (https://github.com/rpavlik/)
|
||||||
|
# - Categorize libs into user and system (https://github.com/rpavlik/)
|
||||||
|
# - Dump size at the end of the build (https://github.com/rpavlik/)
|
||||||
|
# - Lots and lots of improvements (https://github.com/rpavlik/)
|
||||||
|
# - Changed bytes option for the head shell command, so that it works in Mac as well
|
||||||
|
# - Auto detect Serial Baud rate from sketch if possible
|
||||||
|
#
|
||||||
|
# 0.9.3.1 18.viii.2012 jeffkowalski
|
||||||
|
# - Autodetect ARDUINO_LIBS from includes in LOCAL_SRCS
|
||||||
|
# - Autodetect ARDUINO_SKETCHBOOK from file
|
||||||
|
# set by Arduino IDE
|
||||||
|
# - Autodetect ARDMK_DIR based on location of
|
||||||
|
# this file
|
||||||
|
# - Added support for utility directory
|
||||||
|
# within SYS and USER libraries
|
||||||
|
#
|
||||||
|
# 0.9.3.2 10.ix.2012 Sudar
|
||||||
|
# - Fixed a typo in README. Issue reported at upstream (https://github.com/mjoldfield/Arduino-Makefile/issues/21)
|
||||||
|
#
|
||||||
# 0.10 17.ix.12 M J Oldfield
|
# 0.10 17.ix.12 M J Oldfield
|
||||||
# - Added installation notes for Fedora (ex Rickard Lindberg).
|
# - Added installation notes for Fedora (ex Rickard Lindberg).
|
||||||
# - Changed size target so that it looks at the ELF object,
|
# - Changed size target so that it looks at the ELF object,
|
||||||
|
@ -90,6 +128,32 @@
|
||||||
# - Added support for USB_PID/VID used by the Leonardo (ex Dan
|
# - Added support for USB_PID/VID used by the Leonardo (ex Dan
|
||||||
# Villiom Podlaski Christiansen and Marc Plano-Lesay).
|
# Villiom Podlaski Christiansen and Marc Plano-Lesay).
|
||||||
#
|
#
|
||||||
|
# 0.10.1 15.xii.2012 Sudar
|
||||||
|
# - Merged all changes from Upstream and from https://github.com/rpavlik
|
||||||
|
# - Allow passing extra flags (https://github.com/rpavlik)
|
||||||
|
# - Make listing files more useful (https://github.com/rpavlik)
|
||||||
|
# - Add knowledge of device-specific assembler (https://github.com/rpavlik)
|
||||||
|
# - Use variables instead of hardcoded commands (https://github.com/rpavlik)
|
||||||
|
# - Make disasm more helpful (https://github.com/rpavlik)
|
||||||
|
# - Change .sym output (https://github.com/rpavlik)
|
||||||
|
# - Provide symbol_sizes and generated_assembly targets. (https://github.com/rpavlik)
|
||||||
|
# - Be able to silence configuration output (https://github.com/rpavlik)
|
||||||
|
# - Make everybody depend on the makefile, in case cflags are changed, etc. (https://github.com/rpavlik)
|
||||||
|
# - Make the makefile error if the arduino port is not present. (https://github.com/rpavlik)
|
||||||
|
#
|
||||||
|
# 0.10.2 15.xii.2012 Sudar
|
||||||
|
# - Added sketch size verification. (https://github.com/fornellas)
|
||||||
|
# - Show original line number for error messages (https://github.com/WizenedEE)
|
||||||
|
# - Removed -w from CPPFLAGS to show warnings (https://github.com/gaftech)
|
||||||
|
# - Changed shebang to use /usr/bin/env (https://github.com/anm)
|
||||||
|
# - set USB_VID and USB_PID only for leonardo boards(https://github.com/alohr)
|
||||||
|
#
|
||||||
|
# 0.10.3 16.xii 2012 gaftech
|
||||||
|
# - Enabling creation of EEPROM file (.eep)
|
||||||
|
# - EEPROM upload: eeprom and raw_eeprom targets
|
||||||
|
# - Auto EEPROM upload with isp mode: ISP_EEPROM option.
|
||||||
|
# - Allow custom OBJDIR
|
||||||
|
#
|
||||||
########################################################################
|
########################################################################
|
||||||
#
|
#
|
||||||
# PATHS YOU NEED TO SET UP
|
# PATHS YOU NEED TO SET UP
|
||||||
|
@ -129,10 +193,15 @@
|
||||||
# You can either set these up in the Makefile, or put them in your
|
# You can either set these up in the Makefile, or put them in your
|
||||||
# environment e.g. in your .bashrc
|
# environment e.g. in your .bashrc
|
||||||
#
|
#
|
||||||
|
# If you don't specify these, we can try to guess, but that might not work
|
||||||
|
# or work the way you want it to.
|
||||||
|
#
|
||||||
# If you don't install the ard-... binaries to /usr/local/bin, but
|
# If you don't install the ard-... binaries to /usr/local/bin, but
|
||||||
# instead copy them to e.g. /home/mjo/arduino.mk/bin then set
|
# instead copy them to e.g. /home/mjo/arduino.mk/bin then set
|
||||||
# ARDML_DIR = /home/mjo/arduino.mk
|
# ARDML_DIR = /home/mjo/arduino.mk
|
||||||
#
|
#
|
||||||
|
# If you'd rather not see the configuration output, define ARDUINO_QUIET.
|
||||||
|
#
|
||||||
########################################################################
|
########################################################################
|
||||||
#
|
#
|
||||||
# DEPENDENCIES
|
# DEPENDENCIES
|
||||||
|
@ -159,16 +228,28 @@
|
||||||
# Hopefully these will be self-explanatory but in case they're not:
|
# Hopefully these will be self-explanatory but in case they're not:
|
||||||
#
|
#
|
||||||
# ARDUINO_LIBS - A list of any libraries used by the sketch (we
|
# ARDUINO_LIBS - A list of any libraries used by the sketch (we
|
||||||
# assume these are in
|
# assume these are in $(ARDUINO_DIR)/hardware/libraries
|
||||||
# $(ARDUINO_DIR)/hardware/libraries
|
# or your sketchbook's libraries directory)
|
||||||
#
|
#
|
||||||
# ARDUINO_PORT - The port where the Arduino can be found (only needed
|
# ARDUINO_PORT - The port where the Arduino can be found (only needed
|
||||||
# when uploading
|
# when uploading)
|
||||||
#
|
#
|
||||||
# BOARD_TAG - The ard-parse-boards tag for the board e.g. uno or mega
|
# BOARD_TAG - The ard-parse-boards tag for the board e.g. uno or mega
|
||||||
# 'make show_boards' shows a list
|
# 'make show_boards' shows a list
|
||||||
#
|
#
|
||||||
# Once this file has been created the typical workflow is just
|
# If you have your additional libraries relative to your source, rather
|
||||||
|
# than in your "sketchbook", also set USER_LIB_PATH, like this example:
|
||||||
|
#
|
||||||
|
# USER_LIB_PATH := $(realpath ../../libraries)
|
||||||
|
#
|
||||||
|
# If you've added the Arduino-Makefile repository to your git repo as a
|
||||||
|
# submodule (or other similar arrangement), you might have lines like this
|
||||||
|
# in your Makefile:
|
||||||
|
#
|
||||||
|
# ARDMK_DIR := $(realpath ../../tools/Arduino-Makefile)
|
||||||
|
# include $(ARDMK_DIR)/arduino-mk/Arduino.mk
|
||||||
|
#
|
||||||
|
# In any case, once this file has been created the typical workflow is just
|
||||||
#
|
#
|
||||||
# $ make upload
|
# $ make upload
|
||||||
#
|
#
|
||||||
|
@ -188,6 +269,15 @@
|
||||||
# make raw_upload - upload without first resetting
|
# make raw_upload - upload without first resetting
|
||||||
# make show_boards - list all the boards defined in boards.txt
|
# make show_boards - list all the boards defined in boards.txt
|
||||||
# make monitor - connect to the Arduino's serial port
|
# make monitor - connect to the Arduino's serial port
|
||||||
|
# make size - show the size of the compiled output (relative to
|
||||||
|
# resources, if you have a patched avr-size)
|
||||||
|
# make disasm - generate a .lss file in build-cli that contains
|
||||||
|
# disassembly of the compiled file interspersed
|
||||||
|
# with your original source code.
|
||||||
|
# make verify_size - Verify that the size of the final file is less than
|
||||||
|
# the capacity of the micro controller.
|
||||||
|
# make eeprom - upload the eep file
|
||||||
|
# make raw_eeprom - upload the eep file without first resetting
|
||||||
#
|
#
|
||||||
########################################################################
|
########################################################################
|
||||||
#
|
#
|
||||||
|
@ -205,46 +295,8 @@
|
||||||
# bindkey ^C kill
|
# bindkey ^C kill
|
||||||
#
|
#
|
||||||
# If you want to change the baudrate, just set MONITOR_BAUDRATE. If you
|
# If you want to change the baudrate, just set MONITOR_BAUDRATE. If you
|
||||||
# don't set it, it defaults to 9600 baud.
|
# don't set it, it tries to read from the sketch. If it couldn't read
|
||||||
#
|
# from the sketch, then it defaults to 9600 baud.
|
||||||
########################################################################
|
|
||||||
#
|
|
||||||
# PATHS
|
|
||||||
#
|
|
||||||
# I've reworked the way paths to executables are constructed in this
|
|
||||||
# version of Makefile.
|
|
||||||
#
|
|
||||||
# We need to worry about three different sorts of file:
|
|
||||||
#
|
|
||||||
# 1. Things which are included in this distribution e.g. ard-parse-boards
|
|
||||||
# => ARDMK_DIR
|
|
||||||
#
|
|
||||||
# 2. Things which are always in the Arduino distribution e.g.
|
|
||||||
# boards.txt, libraries, &c.
|
|
||||||
# => ARDUINO_DIR
|
|
||||||
#
|
|
||||||
# 3. Things which might be bundled with the Arduino distribution, but
|
|
||||||
# might come from the system. Most of the toolchain is like this:
|
|
||||||
# on Linux it's supplied by the system.
|
|
||||||
# => AVR_TOOLS_DIR
|
|
||||||
#
|
|
||||||
# Having set these three variables, we can work out the rest assuming
|
|
||||||
# that things are canonically arranged beneath the directories defined
|
|
||||||
# above.
|
|
||||||
#
|
|
||||||
# So, on the Mac you might want to set:
|
|
||||||
#
|
|
||||||
# ARDUINO_DIR = /Applications/Arduino.app/Contents/Resources/Java
|
|
||||||
# ARDMK_DIR = /usr/local
|
|
||||||
#
|
|
||||||
# On Linux, you might prefer:
|
|
||||||
#
|
|
||||||
# ARDUINO_DIR = /usr/share/arduino
|
|
||||||
# ARDMK_DIR = /usr/local
|
|
||||||
# AVR_TOOLS_DIR = /usr
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
#
|
||||||
########################################################################
|
########################################################################
|
||||||
#
|
#
|
||||||
|
@ -265,6 +317,9 @@
|
||||||
# ISP_LOW_FUSE = 0xff
|
# ISP_LOW_FUSE = 0xff
|
||||||
# ISP_EXT_FUSE = 0x01
|
# ISP_EXT_FUSE = 0x01
|
||||||
#
|
#
|
||||||
|
# You can specify to also upload the EEPROM file:
|
||||||
|
# ISP_EEPROM = 1
|
||||||
|
#
|
||||||
# I think the fuses here are fine for uploading to the ATmega168
|
# I think the fuses here are fine for uploading to the ATmega168
|
||||||
# without bootloader.
|
# without bootloader.
|
||||||
#
|
#
|
||||||
|
@ -275,72 +330,175 @@
|
||||||
#
|
#
|
||||||
########################################################################
|
########################################################################
|
||||||
|
|
||||||
|
# Useful functions
|
||||||
|
# Returns the first argument (typically a directory), if the file or directory
|
||||||
|
# named by concatenating the first and optionally second argument
|
||||||
|
# (directory and optional filename) exists
|
||||||
|
dir_if_exists = $(if $(wildcard $(1)$(2)),$(1))
|
||||||
|
|
||||||
|
# For message printing: pad the right side of the first argument with spaces to
|
||||||
|
# the number of bytes indicated by the second argument.
|
||||||
|
space_pad_to = $(shell echo $(1) " " | head -c$(2))
|
||||||
|
|
||||||
|
ifndef ARDUINO_QUIET
|
||||||
|
arduino_output = $(info $(1))
|
||||||
|
else
|
||||||
|
arduino_output =
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Call with some text, and a prefix tag if desired (like [AUTODETECTED]),
|
||||||
|
show_config_info = $(call arduino_output,- $(call space_pad_to,$(2),20) $(1))
|
||||||
|
|
||||||
|
# Call with the name of the variable, a prefix tag if desired (like [AUTODETECTED]),
|
||||||
|
# and an explanation if desired (like (found in $$PATH)
|
||||||
|
show_config_variable = $(call show_config_info,$(1) = $($(1)) $(3),$(2))
|
||||||
|
|
||||||
|
# Just a nice simple visual separator
|
||||||
|
show_separator = $(call arduino_output,-------------------------)
|
||||||
|
|
||||||
|
|
||||||
|
$(call show_separator)
|
||||||
|
$(call arduino_output,Arduino.mk Configuration:)
|
||||||
|
|
||||||
|
ifndef ARDUINO_DIR
|
||||||
|
AUTO_ARDUINO_DIR := $(firstword \
|
||||||
|
$(call dir_if_exists,/usr/share/arduino) \
|
||||||
|
$(call dir_if_exists,/Applications/Arduino.app/Contents/Resources/Java) )
|
||||||
|
ifdef AUTO_ARDUINO_DIR
|
||||||
|
ARDUINO_DIR = $(AUTO_ARDUINO_DIR)
|
||||||
|
$(call show_config_variable,ARDUINO_DIR,[AUTODETECTED])
|
||||||
|
endif
|
||||||
|
|
||||||
|
else
|
||||||
|
$(call show_config_variable,ARDUINO_DIR)
|
||||||
|
endif
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
#
|
#
|
||||||
# Default TARGET to cwd (ex Daniele Vergini)
|
# Default TARGET to cwd (ex Daniele Vergini)
|
||||||
ifndef TARGET
|
ifndef TARGET
|
||||||
TARGET = $(notdir $(CURDIR))
|
TARGET = $(notdir $(CURDIR))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
|
|
||||||
#
|
|
||||||
# Arduino version number
|
# Arduino version number
|
||||||
ifndef ARDUINO_VERSION
|
ifndef ARDUINO_VERSION
|
||||||
ARDUINO_VERSION = 100
|
|
||||||
|
# Remove all the decimals, and right-pad with zeros, and finally grab the first 3 bytes.
|
||||||
|
# Works for 1.0 and 1.0.1
|
||||||
|
AUTO_ARDUINO_VERSION := $(shell cat $(ARDUINO_DIR)/lib/version.txt | sed -e 's/[.]//g' -e 's/$$/0000/' | head -c3)
|
||||||
|
ifdef AUTO_ARDUINO_VERSION
|
||||||
|
ARDUINO_VERSION = $(AUTO_ARDUINO_VERSION)
|
||||||
|
$(call show_config_variable,ARDUINO_VERSION,[AUTODETECTED])
|
||||||
|
else
|
||||||
|
ARDUINO_VERSION = 100
|
||||||
|
$(call show_config_variable,ARDUINO_VERSION,[DEFAULT])
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
$(call show_config_variable,ARDUINO_VERSION)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
# Arduino and system paths
|
# Arduino and system paths
|
||||||
#
|
#
|
||||||
ifdef ARDUINO_DIR
|
ifdef ARDUINO_DIR
|
||||||
|
ifndef AVR_TOOLS_DIR
|
||||||
|
BUNDLED_AVR_TOOLS_DIR := $(call dir_if_exists,$(ARDUINO_DIR)/hardware/tools/avr)
|
||||||
|
ifdef BUNDLED_AVR_TOOLS_DIR
|
||||||
|
AVR_TOOLS_DIR = $(BUNDLED_AVR_TOOLS_DIR)
|
||||||
|
# The avrdude bundled with Arduino can't find it's config
|
||||||
|
AVRDUDE_CONF = $(AVR_TOOLS_DIR)/etc/avrdude.conf
|
||||||
|
$(call show_config_variable,AVR_TOOLS_DIR,[BUNDLED],(in Arduino distribution))
|
||||||
|
|
||||||
ifndef AVR_TOOLS_DIR
|
else
|
||||||
AVR_TOOLS_DIR = $(ARDUINO_DIR)/hardware/tools/avr
|
|
||||||
endif
|
|
||||||
# The avrdude bundled with Arduino can't find its config
|
|
||||||
ifndef AVRDUDE_CONF
|
|
||||||
AVRDUDE_CONF = $(ARDUINO_DIR)/hardware/tools/avrdude.conf
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifndef AVR_TOOLS_PATH
|
SYSTEMPATH_AVR_TOOLS_DIR := $(call dir_if_exists,$(abspath $(dir $(shell which avr-gcc))/..))
|
||||||
AVR_TOOLS_PATH = $(AVR_TOOLS_DIR)/bin
|
ifdef SYSTEMPATH_AVR_TOOLS_DIR
|
||||||
endif
|
AVR_TOOLS_DIR = $(SYSTEMPATH_AVR_TOOLS_DIR)
|
||||||
|
$(call show_config_variable,AVR_TOOLS_DIR,[AUTODETECTED],(found in $$PATH))
|
||||||
|
endif # SYSTEMPATH_AVR_TOOLS_DIR
|
||||||
|
|
||||||
ARDUINO_LIB_PATH = $(ARDUINO_DIR)/libraries
|
endif # BUNDLED_AVR_TOOLS_DIR
|
||||||
ARDUINO_CORE_PATH = $(ARDUINO_DIR)/hardware/arduino/cores/arduino
|
|
||||||
ARDUINO_VAR_PATH = $(ARDUINO_DIR)/hardware/arduino/variants
|
else
|
||||||
|
|
||||||
|
$(call show_config_variable,AVR_TOOLS_DIR)
|
||||||
|
endif #ndef AVR_TOOLS_DIR
|
||||||
|
|
||||||
|
ARDUINO_LIB_PATH = $(ARDUINO_DIR)/libraries
|
||||||
|
$(call show_config_variable,ARDUINO_LIB_PATH,[COMPUTED],(from ARDUINO_DIR))
|
||||||
|
ARDUINO_CORE_PATH = $(ARDUINO_DIR)/hardware/arduino/cores/arduino
|
||||||
|
ARDUINO_VAR_PATH = $(ARDUINO_DIR)/hardware/arduino/variants
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
||||||
echo $(error "ARDUINO_DIR is not defined")
|
echo $(error "ARDUINO_DIR is not defined")
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifdef AVR_TOOLS_DIR
|
||||||
|
|
||||||
|
ifndef AVR_TOOLS_PATH
|
||||||
|
AVR_TOOLS_PATH = $(AVR_TOOLS_DIR)/bin
|
||||||
|
endif
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
# Makefile distribution path
|
# Makefile distribution path
|
||||||
#
|
#
|
||||||
ifdef ARDMK_DIR
|
ifndef ARDMK_DIR
|
||||||
|
# presume it's a level above the path to our own file
|
||||||
ifndef ARDMK_PATH
|
ARDMK_DIR := $(realpath $(dir $(realpath $(lastword $(MAKEFILE_LIST))))/..)
|
||||||
ARDMK_PATH = $(ARDMK_DIR)/bin
|
$(call show_config_variable,ARDMK_DIR,[COMPUTED],(relative to $(notdir $(lastword $(MAKEFILE_LIST)))))
|
||||||
endif
|
|
||||||
|
|
||||||
else
|
else
|
||||||
|
$(call show_config_variable,ARDMK_DIR,[USER])
|
||||||
echo $(error "ARDMK_DIR is not defined")
|
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifdef ARDMK_DIR
|
||||||
|
ifndef ARDMK_PATH
|
||||||
|
ARDMK_PATH = $(ARDMK_DIR)/bin
|
||||||
|
$(call show_config_variable,ARDMK_PATH,[COMPUTED],(relative to ARDMK_DIR))
|
||||||
|
else
|
||||||
|
$(call show_config_variable,ARDMK_PATH)
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
echo $(error "ARDMK_DIR is not defined")
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
# Miscellanea
|
# Miscellanea
|
||||||
#
|
#
|
||||||
ifndef ARDUINO_SKETCHBOOK
|
ifndef ARDUINO_SKETCHBOOK
|
||||||
ARDUINO_SKETCHBOOK = $(HOME)/sketchbook
|
ifneq ($(wildcard $(HOME)/.arduino/preferences.txt),)
|
||||||
|
ARDUINO_SKETCHBOOK = $(shell grep --max-count=1 --regexp="sketchbook.path=" \
|
||||||
|
$(HOME)/.arduino/preferences.txt | \
|
||||||
|
sed -e 's/sketchbook.path=//' )
|
||||||
|
endif
|
||||||
|
|
||||||
|
# on mac
|
||||||
|
ifneq ($(wildcard $(HOME)/Library/Arduino/preferences.txt),)
|
||||||
|
ARDUINO_SKETCHBOOK = $(shell grep --max-count=1 --regexp="sketchbook.path=" \
|
||||||
|
$(HOME)/Library/Arduino/preferences.txt | \
|
||||||
|
sed -e 's/sketchbook.path=//' )
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(ARDUINO_SKETCHBOOK),)
|
||||||
|
$(call show_config_variable,ARDUINO_SKETCHBOOK,[AUTODETECTED],(in arduino preferences file))
|
||||||
|
else
|
||||||
|
ARDUINO_SKETCHBOOK = $(HOME)/sketchbook
|
||||||
|
$(call show_config_variable,ARDUINO_SKETCHBOOK,[DEFAULT])
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
$(call show_config_variable,ARDUINO_SKETCHBOOK)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef USER_LIB_PATH
|
ifndef USER_LIB_PATH
|
||||||
USER_LIB_PATH = $(ARDUINO_SKETCHBOOK)/libraries
|
USER_LIB_PATH = $(ARDUINO_SKETCHBOOK)/libraries
|
||||||
|
$(call show_config_variable,USER_LIB_PATH,[DEFAULT],(in user sketchbook))
|
||||||
|
else
|
||||||
|
$(call show_config_variable,USER_LIB_PATH)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
|
@ -351,50 +509,75 @@ endif
|
||||||
# for more information (search for 'character special device').
|
# for more information (search for 'character special device').
|
||||||
#
|
#
|
||||||
ifndef MONITOR_BAUDRATE
|
ifndef MONITOR_BAUDRATE
|
||||||
MONITOR_BAUDRATE = 9600
|
#This works only in linux. TODO: Port it to MAC OS also
|
||||||
|
SPEED = $(shell grep --max-count=1 --regexp="Serial.begin" $$(ls -1 *.ino) | sed -e 's/\t//g' -e 's/\/\/.*$$//g' -e 's/(/\t/' -e 's/)/\t/' | awk -F '\t' '{print $$2}' )
|
||||||
|
MONITOR_BAUDRATE = $(findstring $(SPEED),300 1200 2400 4800 9600 14400 19200 28800 38400 57600 115200)
|
||||||
|
|
||||||
|
ifeq ($(MONITOR_BAUDRATE),)
|
||||||
|
MONITOR_BAUDRATE = 9600
|
||||||
|
$(call show_config_variable,MONITOR_BAUDRATE,[ASSUMED])
|
||||||
|
else
|
||||||
|
$(call show_config_variable,MONITOR_BAUDRATE,[DETECTED], (in sketch))
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
$(call show_config_variable,MONITOR_BAUDRATE, [SPECIFIED])
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef MONITOR_CMD
|
ifndef MONITOR_CMD
|
||||||
MONITOR_CMD = screen
|
MONITOR_CMD = screen
|
||||||
|
endif
|
||||||
|
|
||||||
|
########################################################################
|
||||||
|
# Reset
|
||||||
|
#
|
||||||
|
ifndef RESET_CMD
|
||||||
|
ifeq ($(BOARD_TAG),leonardo)
|
||||||
|
RESET_CMD = $(ARDMK_PATH)/ard-reset-leonardo $(ARD_RESET_OPTS)
|
||||||
|
else
|
||||||
|
RESET_CMD = $(ARDMK_PATH)/ard-reset-arduino $(ARD_RESET_OPTS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
# boards.txt parsing
|
# boards.txt parsing
|
||||||
#
|
#
|
||||||
ifndef BOARD_TAG
|
ifndef BOARD_TAG
|
||||||
BOARD_TAG = uno
|
BOARD_TAG = uno
|
||||||
|
$(call show_config_variable,BOARD_TAG,[DEFAULT])
|
||||||
|
else
|
||||||
|
$(call show_config_variable,BOARD_TAG)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef BOARDS_TXT
|
ifndef BOARDS_TXT
|
||||||
BOARDS_TXT = $(ARDUINO_DIR)/hardware/arduino/boards.txt
|
BOARDS_TXT = $(ARDUINO_DIR)/hardware/arduino/boards.txt
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef PARSE_BOARD
|
ifndef PARSE_BOARD
|
||||||
PARSE_BOARD = $(ARDMK_PATH)/ard-parse-boards
|
PARSE_BOARD = $(ARDMK_PATH)/ard-parse-boards
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef PARSE_BOARD_OPTS
|
ifndef PARSE_BOARD_OPTS
|
||||||
PARSE_BOARD_OPTS = --boards_txt=$(BOARDS_TXT)
|
PARSE_BOARD_OPTS = --boards_txt=$(BOARDS_TXT)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef PARSE_BOARD_CMD
|
ifndef PARSE_BOARD_CMD
|
||||||
PARSE_BOARD_CMD = $(PARSE_BOARD) $(PARSE_BOARD_OPTS)
|
PARSE_BOARD_CMD = $(PARSE_BOARD) $(PARSE_BOARD_OPTS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Which variant ? This affects the include path
|
# Which variant ? This affects the include path
|
||||||
ifndef VARIANT
|
ifndef VARIANT
|
||||||
VARIANT = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.variant)
|
VARIANT = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.variant)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# processor stuff
|
# processor stuff
|
||||||
ifndef MCU
|
ifndef MCU
|
||||||
MCU = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.mcu)
|
MCU = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.mcu)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef F_CPU
|
ifndef F_CPU
|
||||||
F_CPU = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.f_cpu)
|
F_CPU = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.f_cpu)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(VARIANT),leonardo)
|
||||||
# USB IDs for the Leonardo
|
# USB IDs for the Leonardo
|
||||||
ifndef USB_VID
|
ifndef USB_VID
|
||||||
USB_VID = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.vid)
|
USB_VID = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.vid)
|
||||||
|
@ -403,35 +586,36 @@ endif
|
||||||
ifndef USB_PID
|
ifndef USB_PID
|
||||||
USB_PID = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.pid)
|
USB_PID = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) build.pid)
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
# normal programming info
|
# normal programming info
|
||||||
ifndef AVRDUDE_ARD_PROGRAMMER
|
ifndef AVRDUDE_ARD_PROGRAMMER
|
||||||
AVRDUDE_ARD_PROGRAMMER = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) upload.protocol)
|
AVRDUDE_ARD_PROGRAMMER = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) upload.protocol)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef AVRDUDE_ARD_BAUDRATE
|
ifndef AVRDUDE_ARD_BAUDRATE
|
||||||
AVRDUDE_ARD_BAUDRATE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) upload.speed)
|
AVRDUDE_ARD_BAUDRATE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) upload.speed)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# fuses if you're using e.g. ISP
|
# fuses if you're using e.g. ISP
|
||||||
ifndef ISP_LOCK_FUSE_PRE
|
ifndef ISP_LOCK_FUSE_PRE
|
||||||
ISP_LOCK_FUSE_PRE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.unlock_bits)
|
ISP_LOCK_FUSE_PRE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.unlock_bits)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef ISP_LOCK_FUSE_POST
|
ifndef ISP_LOCK_FUSE_POST
|
||||||
ISP_LOCK_FUSE_POST = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.lock_bits)
|
ISP_LOCK_FUSE_POST = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.lock_bits)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef ISP_HIGH_FUSE
|
ifndef ISP_HIGH_FUSE
|
||||||
ISP_HIGH_FUSE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.high_fuses)
|
ISP_HIGH_FUSE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.high_fuses)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef ISP_LOW_FUSE
|
ifndef ISP_LOW_FUSE
|
||||||
ISP_LOW_FUSE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.low_fuses)
|
ISP_LOW_FUSE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.low_fuses)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef ISP_EXT_FUSE
|
ifndef ISP_EXT_FUSE
|
||||||
ISP_EXT_FUSE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.extended_fuses)
|
ISP_EXT_FUSE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) bootloader.extended_fuses)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Everything gets built in here (include BOARD_TAG now)
|
# Everything gets built in here (include BOARD_TAG now)
|
||||||
|
@ -439,26 +623,22 @@ ifndef OBJDIR
|
||||||
OBJDIR = build-$(BOARD_TAG)
|
OBJDIR = build-$(BOARD_TAG)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifndef HEX_MAXIMUM_SIZE
|
||||||
########################################################################
|
HEX_MAXIMUM_SIZE = $(shell $(PARSE_BOARD_CMD) $(BOARD_TAG) upload.maximum_size)
|
||||||
# Reset
|
|
||||||
ifndef RESET_CMD
|
|
||||||
ifeq ($(BOARD_TAG),leonardo)
|
|
||||||
RESET_CMD = $(ARDMK_PATH)/ard-reset-leonardo $(ARD_RESET_OPTS)
|
|
||||||
else
|
|
||||||
RESET_CMD = $(ARDMK_PATH)/ard-reset-arduino $(ARD_RESET_OPTS)
|
|
||||||
endif
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
# Local sources
|
# Local sources
|
||||||
#
|
#
|
||||||
LOCAL_C_SRCS = $(wildcard *.c)
|
LOCAL_C_SRCS ?= $(wildcard *.c)
|
||||||
LOCAL_CPP_SRCS = $(wildcard *.cpp)
|
LOCAL_CPP_SRCS ?= $(wildcard *.cpp)
|
||||||
LOCAL_CC_SRCS = $(wildcard *.cc)
|
LOCAL_CC_SRCS ?= $(wildcard *.cc)
|
||||||
LOCAL_PDE_SRCS = $(wildcard *.pde)
|
LOCAL_PDE_SRCS ?= $(wildcard *.pde)
|
||||||
LOCAL_INO_SRCS = $(wildcard *.ino)
|
LOCAL_INO_SRCS ?= $(wildcard *.ino)
|
||||||
LOCAL_AS_SRCS = $(wildcard *.S)
|
LOCAL_AS_SRCS ?= $(wildcard *.S)
|
||||||
|
LOCAL_SRCS = $(LOCAL_C_SRCS) $(LOCAL_CPP_SRCS) \
|
||||||
|
$(LOCAL_CC_SRCS) $(LOCAL_PDE_SRCS) \
|
||||||
|
$(LOCAL_INO_SRCS) $(LOCAL_AS_SRCS)
|
||||||
LOCAL_OBJ_FILES = $(LOCAL_C_SRCS:.c=.o) $(LOCAL_CPP_SRCS:.cpp=.o) \
|
LOCAL_OBJ_FILES = $(LOCAL_C_SRCS:.c=.o) $(LOCAL_CPP_SRCS:.cpp=.o) \
|
||||||
$(LOCAL_CC_SRCS:.cc=.o) $(LOCAL_PDE_SRCS:.pde=.o) \
|
$(LOCAL_CC_SRCS:.cc=.o) $(LOCAL_PDE_SRCS:.pde=.o) \
|
||||||
$(LOCAL_INO_SRCS:.ino=.o) $(LOCAL_AS_SRCS:.S=.o)
|
$(LOCAL_INO_SRCS:.ino=.o) $(LOCAL_AS_SRCS:.S=.o)
|
||||||
|
@ -469,20 +649,33 @@ DEPS = $(LOCAL_OBJS:.o=.d)
|
||||||
|
|
||||||
# core sources
|
# core sources
|
||||||
ifeq ($(strip $(NO_CORE)),)
|
ifeq ($(strip $(NO_CORE)),)
|
||||||
ifdef ARDUINO_CORE_PATH
|
ifdef ARDUINO_CORE_PATH
|
||||||
CORE_C_SRCS = $(wildcard $(ARDUINO_CORE_PATH)/*.c)
|
CORE_C_SRCS = $(wildcard $(ARDUINO_CORE_PATH)/*.c)
|
||||||
CORE_CPP_SRCS = $(wildcard $(ARDUINO_CORE_PATH)/*.cpp)
|
CORE_CPP_SRCS = $(wildcard $(ARDUINO_CORE_PATH)/*.cpp)
|
||||||
|
|
||||||
ifneq ($(strip $(NO_CORE_MAIN_CPP)),)
|
ifneq ($(strip $(NO_CORE_MAIN_CPP)),)
|
||||||
CORE_CPP_SRCS := $(filter-out %main.cpp, $(CORE_CPP_SRCS))
|
CORE_CPP_SRCS := $(filter-out %main.cpp, $(CORE_CPP_SRCS))
|
||||||
|
$(call show_config_info,NO_CORE_MAIN_CPP set so core library will not include main.cpp,[MANUAL])
|
||||||
|
endif
|
||||||
|
|
||||||
|
CORE_OBJ_FILES = $(CORE_C_SRCS:.c=.o) $(CORE_CPP_SRCS:.cpp=.o)
|
||||||
|
CORE_OBJS = $(patsubst $(ARDUINO_CORE_PATH)/%, \
|
||||||
|
$(OBJDIR)/%,$(CORE_OBJ_FILES))
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
$(call show_config_info,NO_CORE set so core library will not be built,[MANUAL])
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CORE_OBJ_FILES = $(CORE_C_SRCS:.c=.o) $(CORE_CPP_SRCS:.cpp=.o)
|
########################################################################
|
||||||
CORE_OBJS = $(patsubst $(ARDUINO_CORE_PATH)/%, \
|
# Determine ARDUINO_LIBS automatically
|
||||||
$(OBJDIR)/%,$(CORE_OBJ_FILES))
|
#
|
||||||
|
ifndef ARDUINO_LIBS
|
||||||
|
# automatically determine included libraries
|
||||||
|
ARDUINO_LIBS += $(filter $(notdir $(wildcard $(ARDUINO_DIR)/libraries/*)), \
|
||||||
|
$(shell sed -ne "s/^ *\# *include *[<\"]\(.*\)\.h[>\"]/\1/p" $(LOCAL_SRCS)))
|
||||||
|
ARDUINO_LIBS += $(filter $(notdir $(wildcard $(ARDUINO_SKETCHBOOK)/libraries/*)), \
|
||||||
|
$(shell sed -ne "s/^ *\# *include *[<\"]\(.*\)\.h[>\"]/\1/p" $(LOCAL_SRCS)))
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
|
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
# Rules for making stuff
|
# Rules for making stuff
|
||||||
|
@ -491,6 +684,7 @@ endif
|
||||||
# The name of the main targets
|
# The name of the main targets
|
||||||
TARGET_HEX = $(OBJDIR)/$(TARGET).hex
|
TARGET_HEX = $(OBJDIR)/$(TARGET).hex
|
||||||
TARGET_ELF = $(OBJDIR)/$(TARGET).elf
|
TARGET_ELF = $(OBJDIR)/$(TARGET).elf
|
||||||
|
TARGET_EEP = $(OBJDIR)/$(TARGET).eep
|
||||||
TARGETS = $(OBJDIR)/$(TARGET).*
|
TARGETS = $(OBJDIR)/$(TARGET).*
|
||||||
CORE_LIB = $(OBJDIR)/libcore.a
|
CORE_LIB = $(OBJDIR)/libcore.a
|
||||||
|
|
||||||
|
@ -500,19 +694,33 @@ DEP_FILE = $(OBJDIR)/depends.mk
|
||||||
# Names of executables
|
# Names of executables
|
||||||
CC = $(AVR_TOOLS_PATH)/avr-gcc
|
CC = $(AVR_TOOLS_PATH)/avr-gcc
|
||||||
CXX = $(AVR_TOOLS_PATH)/avr-g++
|
CXX = $(AVR_TOOLS_PATH)/avr-g++
|
||||||
|
AS = $(AVR_TOOLS_PATH)/avr-as
|
||||||
OBJCOPY = $(AVR_TOOLS_PATH)/avr-objcopy
|
OBJCOPY = $(AVR_TOOLS_PATH)/avr-objcopy
|
||||||
OBJDUMP = $(AVR_TOOLS_PATH)/avr-objdump
|
OBJDUMP = $(AVR_TOOLS_PATH)/avr-objdump
|
||||||
AR = $(AVR_TOOLS_PATH)/avr-ar
|
AR = $(AVR_TOOLS_PATH)/avr-ar
|
||||||
SIZE = $(AVR_TOOLS_PATH)/avr-size
|
SIZE = $(AVR_TOOLS_PATH)/avr-size
|
||||||
NM = $(AVR_TOOLS_PATH)/avr-nm
|
NM = $(AVR_TOOLS_PATH)/avr-nm
|
||||||
REMOVE = rm -f
|
REMOVE = rm -rf
|
||||||
MV = mv -f
|
MV = mv -f
|
||||||
CAT = cat
|
CAT = cat
|
||||||
ECHO = echo
|
ECHO = echo
|
||||||
|
|
||||||
# General arguments
|
# General arguments
|
||||||
SYS_LIBS = $(patsubst %,$(ARDUINO_LIB_PATH)/%,$(ARDUINO_LIBS))
|
USER_LIBS = $(wildcard $(patsubst %,$(USER_LIB_PATH)/%,$(ARDUINO_LIBS)))
|
||||||
USER_LIBS = $(patsubst %,$(USER_LIB_PATH)/%,$(ARDUINO_LIBS))
|
USER_LIB_NAMES= $(patsubst $(USER_LIB_PATH)/%,%,$(USER_LIBS))
|
||||||
|
|
||||||
|
# Let user libraries override system ones.
|
||||||
|
SYS_LIBS = $(wildcard $(patsubst %,$(ARDUINO_LIB_PATH)/%,$(filter-out $(USER_LIB_NAMES),$(ARDUINO_LIBS))))
|
||||||
|
SYS_LIB_NAMES = $(patsubst $(ARDUINO_LIB_PATH)/%,%,$(SYS_LIBS))
|
||||||
|
|
||||||
|
# Error here if any are missing.
|
||||||
|
LIBS_NOT_FOUND = $(filter-out $(USER_LIB_NAMES) $(SYS_LIB_NAMES),$(ARDUINO_LIBS))
|
||||||
|
ifneq (,$(strip $(LIBS_NOT_FOUND)))
|
||||||
|
$(error The following libraries specified in ARDUINO_LIBS could not be found (searched USER_LIB_PATH and ARDUINO_LIB_PATH): $(LIBS_NOT_FOUND))
|
||||||
|
endif
|
||||||
|
|
||||||
|
SYS_LIBS := $(wildcard $(SYS_LIBS) $(addsuffix /utility,$(SYS_LIBS)))
|
||||||
|
USER_LIBS := $(wildcard $(USER_LIBS) $(addsuffix /utility,$(USER_LIBS)))
|
||||||
SYS_INCLUDES = $(patsubst %,-I%,$(SYS_LIBS))
|
SYS_INCLUDES = $(patsubst %,-I%,$(SYS_LIBS))
|
||||||
USER_INCLUDES = $(patsubst %,-I%,$(USER_LIBS))
|
USER_INCLUDES = $(patsubst %,-I%,$(USER_LIBS))
|
||||||
LIB_C_SRCS = $(wildcard $(patsubst %,%/*.c,$(SYS_LIBS)))
|
LIB_C_SRCS = $(wildcard $(patsubst %,%/*.c,$(SYS_LIBS)))
|
||||||
|
@ -524,19 +732,50 @@ LIB_OBJS = $(patsubst $(ARDUINO_LIB_PATH)/%.c,$(OBJDIR)/libs/%.o,$(LIB_C_SR
|
||||||
USER_LIB_OBJS = $(patsubst $(USER_LIB_PATH)/%.cpp,$(OBJDIR)/libs/%.o,$(USER_LIB_CPP_SRCS)) \
|
USER_LIB_OBJS = $(patsubst $(USER_LIB_PATH)/%.cpp,$(OBJDIR)/libs/%.o,$(USER_LIB_CPP_SRCS)) \
|
||||||
$(patsubst $(USER_LIB_PATH)/%.c,$(OBJDIR)/libs/%.o,$(USER_LIB_C_SRCS))
|
$(patsubst $(USER_LIB_PATH)/%.c,$(OBJDIR)/libs/%.o,$(USER_LIB_C_SRCS))
|
||||||
|
|
||||||
CPPFLAGS = -mmcu=$(MCU) -DF_CPU=$(F_CPU) -DARDUINO=$(ARDUINO_VERSION) \
|
# Using += instead of =, so that CPPFLAGS can be set per sketch level
|
||||||
|
CPPFLAGS += -mmcu=$(MCU) -DF_CPU=$(F_CPU) -DARDUINO=$(ARDUINO_VERSION) \
|
||||||
-I. -I$(ARDUINO_CORE_PATH) -I$(ARDUINO_VAR_PATH)/$(VARIANT) \
|
-I. -I$(ARDUINO_CORE_PATH) -I$(ARDUINO_VAR_PATH)/$(VARIANT) \
|
||||||
$(SYS_INCLUDES) $(USER_INCLUDES) -g -Os -w -Wall \
|
$(SYS_INCLUDES) $(USER_INCLUDES) -g -Os -Wall \
|
||||||
-DUSB_VID=$(USB_VID) -DUSB_PID=$(USB_PID) \
|
-DUSB_VID=$(USB_VID) -DUSB_PID=$(USB_PID) \
|
||||||
-ffunction-sections -fdata-sections
|
-ffunction-sections -fdata-sections
|
||||||
|
CFLAGS += -std=gnu99 $(EXTRA_FLAGS) $(EXTRA_CFLAGS)
|
||||||
|
CXXFLAGS += -fno-exceptions $(EXTRA_FLAGS) $(EXTRA_CXXFLAGS)
|
||||||
|
ASFLAGS += -mmcu=$(MCU) -I. -x assembler-with-cpp
|
||||||
|
LDFLAGS += -mmcu=$(MCU) -Wl,--gc-sections -Os $(EXTRA_FLAGS) $(EXTRA_CXXFLAGS)
|
||||||
|
SIZEFLAGS ?= --mcu=$(MCU) -C
|
||||||
|
|
||||||
CFLAGS = -std=gnu99
|
# Returns the Arduino port (first wildcard expansion) if it exists, otherwise it errors.
|
||||||
CXXFLAGS = -fno-exceptions
|
get_arduino_port = $(if $(wildcard $(ARDUINO_PORT)),$(firstword $(wildcard $(ARDUINO_PORT))),$(error Arduino port $(ARDUINO_PORT) not found!))
|
||||||
ASFLAGS = -mmcu=$(MCU) -I. -x assembler-with-cpp
|
|
||||||
LDFLAGS = -mmcu=$(MCU) -Wl,--gc-sections -Os
|
# Command for avr_size: do $(call avr_size,elffile,hexfile)
|
||||||
|
ifneq (,$(findstring AVR,$(shell $(SIZE) --help)))
|
||||||
|
# We have a patched version of binutils that mentions AVR - pass the MCU
|
||||||
|
# and the elf to get nice output.
|
||||||
|
#avr_size = $(SIZE) --mcu=$(MCU) --format=avr $(1)
|
||||||
|
avr_size = $(SIZE) $(SIZEFLAGS) --format=avr $(1)
|
||||||
|
$(call show_config_info,Size utility: AVR-aware for enhanced output,[AUTODETECTED])
|
||||||
|
else
|
||||||
|
# We have a plain-old binutils version - just give it the hex.
|
||||||
|
avr_size = $(SIZE) $(2)
|
||||||
|
$(call show_config_info,Size utility: Basic (not AVR-aware),[AUTODETECTED])
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
ifneq (,$(strip $(ARDUINO_LIBS)))
|
||||||
|
$(call arduino_output,-)
|
||||||
|
$(call show_config_info,ARDUINO_LIBS =)
|
||||||
|
endif
|
||||||
|
ifneq (,$(strip $(USER_LIB_NAMES)))
|
||||||
|
$(foreach lib,$(USER_LIB_NAMES),$(call show_config_info, $(lib),[USER]))
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq (,$(strip $(SYS_LIB_NAMES)))
|
||||||
|
$(foreach lib,$(SYS_LIB_NAMES),$(call show_config_info, $(lib),[SYSTEM]))
|
||||||
|
endif
|
||||||
|
|
||||||
|
# end of config output
|
||||||
|
$(call show_separator)
|
||||||
|
|
||||||
# Expand and pick the first port
|
|
||||||
ARD_PORT = $(firstword $(wildcard $(ARDUINO_PORT)))
|
|
||||||
|
|
||||||
# Implicit rules for building everything (needed to get everything in
|
# Implicit rules for building everything (needed to get everything in
|
||||||
# the right directory)
|
# the right directory)
|
||||||
|
@ -566,101 +805,137 @@ $(OBJDIR)/libs/%.o: $(USER_LIB_PATH)/%.c
|
||||||
# normal local sources
|
# normal local sources
|
||||||
# .o rules are for objects, .d for dependency tracking
|
# .o rules are for objects, .d for dependency tracking
|
||||||
# there seems to be an awful lot of duplication here!!!
|
# there seems to be an awful lot of duplication here!!!
|
||||||
$(OBJDIR)/%.o: %.c
|
COMMON_DEPS := Makefile
|
||||||
|
$(OBJDIR)/%.o: %.c $(COMMON_DEPS)
|
||||||
$(CC) -c $(CPPFLAGS) $(CFLAGS) $< -o $@
|
$(CC) -c $(CPPFLAGS) $(CFLAGS) $< -o $@
|
||||||
|
|
||||||
$(OBJDIR)/%.o: %.cc
|
$(OBJDIR)/%.o: %.cc $(COMMON_DEPS)
|
||||||
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
||||||
|
|
||||||
$(OBJDIR)/%.o: %.cpp
|
$(OBJDIR)/%.o: %.cpp $(COMMON_DEPS)
|
||||||
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
||||||
|
|
||||||
$(OBJDIR)/%.o: %.S
|
$(OBJDIR)/%.o: %.S $(COMMON_DEPS)
|
||||||
$(CC) -c $(CPPFLAGS) $(ASFLAGS) $< -o $@
|
$(CC) -c $(CPPFLAGS) $(ASFLAGS) $< -o $@
|
||||||
|
|
||||||
$(OBJDIR)/%.o: %.s
|
$(OBJDIR)/%.o: %.s $(COMMON_DEPS)
|
||||||
$(CC) -c $(CPPFLAGS) $(ASFLAGS) $< -o $@
|
$(CC) -c $(CPPFLAGS) $(ASFLAGS) $< -o $@
|
||||||
|
|
||||||
$(OBJDIR)/%.d: %.c
|
$(OBJDIR)/%.d: %.c $(COMMON_DEPS)
|
||||||
$(CC) -MM $(CPPFLAGS) $(CFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
$(CC) -MM $(CPPFLAGS) $(CFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
||||||
|
|
||||||
$(OBJDIR)/%.d: %.cc
|
$(OBJDIR)/%.d: %.cc $(COMMON_DEPS)
|
||||||
$(CXX) -MM $(CPPFLAGS) $(CXXFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
$(CXX) -MM $(CPPFLAGS) $(CXXFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
||||||
|
|
||||||
$(OBJDIR)/%.d: %.cpp
|
$(OBJDIR)/%.d: %.cpp $(COMMON_DEPS)
|
||||||
$(CXX) -MM $(CPPFLAGS) $(CXXFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
$(CXX) -MM $(CPPFLAGS) $(CXXFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
||||||
|
|
||||||
$(OBJDIR)/%.d: %.S
|
$(OBJDIR)/%.d: %.S $(COMMON_DEPS)
|
||||||
$(CC) -MM $(CPPFLAGS) $(ASFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
$(CC) -MM $(CPPFLAGS) $(ASFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
||||||
|
|
||||||
$(OBJDIR)/%.d: %.s
|
$(OBJDIR)/%.d: %.s $(COMMON_DEPS)
|
||||||
$(CC) -MM $(CPPFLAGS) $(ASFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
$(CC) -MM $(CPPFLAGS) $(ASFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
||||||
|
|
||||||
|
#backward compatibility for .pde files
|
||||||
|
# We should check for Arduino version, if the file is .pde because a .pde file might be used in Arduino 1.0
|
||||||
# the pde -> cpp -> o file
|
# the pde -> cpp -> o file
|
||||||
$(OBJDIR)/%.cpp: %.pde
|
$(OBJDIR)/%.cpp: %.pde $(COMMON_DEPS)
|
||||||
$(ECHO) '#include "WProgram.h"' > $@
|
$(ECHO) '#if ARDUINO >= 100\n #include "Arduino.h"\n#else\n #include "WProgram.h"\n#endif\n#line 1' > $@
|
||||||
$(CAT) $< >> $@
|
$(CAT) $< >> $@
|
||||||
|
|
||||||
# the ino -> cpp -> o file
|
# the ino -> cpp -> o file
|
||||||
$(OBJDIR)/%.cpp: %.ino
|
$(OBJDIR)/%.cpp: %.ino $(COMMON_DEPS)
|
||||||
$(ECHO) '#include <Arduino.h>' > $@
|
$(ECHO) '#include <Arduino.h>\n#line 1' > $@
|
||||||
$(CAT) $< >> $@
|
$(CAT) $< >> $@
|
||||||
|
|
||||||
$(OBJDIR)/%.o: $(OBJDIR)/%.cpp
|
$(OBJDIR)/%.o: $(OBJDIR)/%.cpp $(COMMON_DEPS)
|
||||||
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
||||||
|
|
||||||
$(OBJDIR)/%.d: $(OBJDIR)/%.cpp
|
$(OBJDIR)/%.d: $(OBJDIR)/%.cpp $(COMMON_DEPS)
|
||||||
$(CXX) -MM $(CPPFLAGS) $(CXXFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
$(CXX) -MM $(CPPFLAGS) $(CXXFLAGS) $< -MF $@ -MT $(@:.d=.o)
|
||||||
|
|
||||||
|
# generated assembly
|
||||||
|
$(OBJDIR)/%.s: $(OBJDIR)/%.cpp $(COMMON_DEPS)
|
||||||
|
$(CXX) -S -fverbose-asm $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
||||||
|
|
||||||
|
#$(OBJDIR)/%.lst: $(OBJDIR)/%.s
|
||||||
|
# $(AS) -mmcu=$(MCU) -alhnd $< > $@
|
||||||
|
|
||||||
# core files
|
# core files
|
||||||
$(OBJDIR)/%.o: $(ARDUINO_CORE_PATH)/%.c
|
$(OBJDIR)/%.o: $(ARDUINO_CORE_PATH)/%.c $(COMMON_DEPS)
|
||||||
$(CC) -c $(CPPFLAGS) $(CFLAGS) $< -o $@
|
$(CC) -c $(CPPFLAGS) $(CFLAGS) $< -o $@
|
||||||
|
|
||||||
$(OBJDIR)/%.o: $(ARDUINO_CORE_PATH)/%.cpp
|
$(OBJDIR)/%.o: $(ARDUINO_CORE_PATH)/%.cpp $(COMMON_DEPS)
|
||||||
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
|
||||||
|
|
||||||
# various object conversions
|
# various object conversions
|
||||||
$(OBJDIR)/%.hex: $(OBJDIR)/%.elf
|
$(OBJDIR)/%.hex: $(OBJDIR)/%.elf $(COMMON_DEPS)
|
||||||
$(OBJCOPY) -O ihex -R .eeprom $< $@
|
$(OBJCOPY) -O ihex -R .eeprom $< $@
|
||||||
|
@$(ECHO)
|
||||||
|
@$(ECHO)
|
||||||
|
$(call avr_size,$<,$@)
|
||||||
|
|
||||||
$(OBJDIR)/%.eep: $(OBJDIR)/%.elf
|
$(OBJDIR)/%.eep: $(OBJDIR)/%.elf $(COMMON_DEPS)
|
||||||
-$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \
|
-$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \
|
||||||
--change-section-lma .eeprom=0 -O ihex $< $@
|
--change-section-lma .eeprom=0 -O ihex $< $@
|
||||||
|
|
||||||
$(OBJDIR)/%.lss: $(OBJDIR)/%.elf
|
$(OBJDIR)/%.lss: $(OBJDIR)/%.elf $(COMMON_DEPS)
|
||||||
$(OBJDUMP) -h -S $< > $@
|
$(OBJDUMP) -h --source --demangle --wide $< > $@
|
||||||
|
|
||||||
$(OBJDIR)/%.sym: $(OBJDIR)/%.elf
|
$(OBJDIR)/%.sym: $(OBJDIR)/%.elf $(COMMON_DEPS)
|
||||||
$(NM) -n $< > $@
|
$(NM) --size-sort --demangle --reverse-sort --line-numbers $< > $@
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
#
|
#
|
||||||
# Avrdude
|
# Avrdude
|
||||||
#
|
#
|
||||||
ifndef AVRDUDE
|
ifndef AVRDUDE
|
||||||
AVRDUDE = $(AVR_TOOLS_PATH)/avrdude
|
AVRDUDE = $(AVR_TOOLS_PATH)/avrdude
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifndef AVRDUDE_CONF
|
||||||
|
ifndef AVR_TOOLS_DIR
|
||||||
|
# The avrdude bundled with Arduino can't find its config
|
||||||
|
AVRDUDE_CONF = $(AVR_TOOLS_DIR)/etc/avrdude.conf
|
||||||
|
endif
|
||||||
|
# If avrdude is installed separately, it can find its own config flie
|
||||||
endif
|
endif
|
||||||
|
|
||||||
AVRDUDE_COM_OPTS = -q -V -p $(MCU)
|
AVRDUDE_COM_OPTS = -q -V -p $(MCU)
|
||||||
ifdef AVRDUDE_CONF
|
ifdef AVRDUDE_CONF
|
||||||
AVRDUDE_COM_OPTS += -C $(AVRDUDE_CONF)
|
AVRDUDE_COM_OPTS += -C $(AVRDUDE_CONF)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
AVRDUDE_ARD_OPTS = -c $(AVRDUDE_ARD_PROGRAMMER) -b $(AVRDUDE_ARD_BAUDRATE) -P $(ARD_PORT)
|
AVRDUDE_ARD_OPTS = -c $(AVRDUDE_ARD_PROGRAMMER) -b $(AVRDUDE_ARD_BAUDRATE) -P $(call get_arduino_port)
|
||||||
|
|
||||||
ifndef ISP_PROG
|
ifndef ISP_PROG
|
||||||
ISP_PROG = -c stk500v2
|
ISP_PROG = -c stk500v2
|
||||||
|
endif
|
||||||
|
|
||||||
|
# usb seems to be a reasonable default, at least on linux
|
||||||
|
ifndef ISP_PORT
|
||||||
|
ISP_PORT = usb
|
||||||
endif
|
endif
|
||||||
|
|
||||||
AVRDUDE_ISP_OPTS = -P $(ISP_PORT) $(ISP_PROG)
|
AVRDUDE_ISP_OPTS = -P $(ISP_PORT) $(ISP_PROG)
|
||||||
|
|
||||||
|
ifndef ISP_EEPROM
|
||||||
|
ISP_EEPROM = 0
|
||||||
|
endif
|
||||||
|
|
||||||
|
AVRDUDE_UPLOAD_HEX = -U flash:w:$(TARGET_HEX):i
|
||||||
|
AVRDUDE_UPLOAD_EEP = -U eeprom:w:$(TARGET_EEP):i
|
||||||
|
AVRDUDE_ISPLOAD_OPTS = $(AVRDUDE_UPLOAD_HEX)
|
||||||
|
ifneq ($(ISP_EEPROM), 0)
|
||||||
|
AVRDUDE_ISPLOAD_OPTS += $(AVRDUDE_UPLOAD_EEP)
|
||||||
|
endif
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
#
|
#
|
||||||
# Explicit targets start here
|
# Explicit targets start here
|
||||||
#
|
#
|
||||||
|
|
||||||
all: $(OBJDIR) $(TARGET_HEX)
|
all: $(OBJDIR) $(TARGET_EEP) $(TARGET_HEX) verify_size
|
||||||
|
|
||||||
$(OBJDIR):
|
$(OBJDIR):
|
||||||
mkdir $(OBJDIR)
|
mkdir $(OBJDIR)
|
||||||
|
@ -674,20 +949,28 @@ $(CORE_LIB): $(CORE_OBJS) $(LIB_OBJS) $(USER_LIB_OBJS)
|
||||||
$(DEP_FILE): $(OBJDIR) $(DEPS)
|
$(DEP_FILE): $(OBJDIR) $(DEPS)
|
||||||
cat $(DEPS) > $(DEP_FILE)
|
cat $(DEPS) > $(DEP_FILE)
|
||||||
|
|
||||||
upload: reset raw_upload
|
upload: raw_upload
|
||||||
|
|
||||||
raw_upload: $(TARGET_HEX)
|
raw_upload: reset $(TARGET_HEX) verify_size
|
||||||
|
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ARD_OPTS) \
|
||||||
|
$(AVRDUDE_UPLOAD_HEX)
|
||||||
|
|
||||||
|
eeprom: raw_eeprom
|
||||||
|
|
||||||
|
raw_eeprom: reset $(TARGET_EEP) $(TARGET_HEX)
|
||||||
|
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ARD_OPTS) \
|
||||||
|
$(AVRDUDE_UPLOAD_EEP)
|
||||||
|
|
||||||
|
# the last part is for leonardo.
|
||||||
|
# wait until leonardo reboots and establish a new connection.
|
||||||
|
reset:
|
||||||
|
$(ECHO) "Resetting Arduino..."
|
||||||
|
$(RESET_CMD) $(call get_arduino_port)
|
||||||
while [ ! -e $(ARD_PORT) ] ;\
|
while [ ! -e $(ARD_PORT) ] ;\
|
||||||
do \
|
do \
|
||||||
echo "Waiting for arduino at $(ARD_PORT)";\
|
echo "Waiting for arduino at $(ARD_PORT)";\
|
||||||
sleep 0.3 ;\
|
sleep 0.3 ;\
|
||||||
done
|
done
|
||||||
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ARD_OPTS) \
|
|
||||||
-U flash:w:$(TARGET_HEX):i
|
|
||||||
|
|
||||||
reset:
|
|
||||||
$(ECHO) "Resetting Arduino..."
|
|
||||||
$(RESET_CMD) $(ARD_PORT)
|
|
||||||
|
|
||||||
# stty on MacOS likes -F, but on Debian it likes -f redirecting
|
# stty on MacOS likes -F, but on Debian it likes -f redirecting
|
||||||
# stdin/out appears to work but generates a spurious error on MacOS at
|
# stdin/out appears to work but generates a spurious error on MacOS at
|
||||||
|
@ -696,36 +979,54 @@ reset_stty:
|
||||||
for STTYF in 'stty -F' 'stty --file' 'stty -f' 'stty <' ; \
|
for STTYF in 'stty -F' 'stty --file' 'stty -f' 'stty <' ; \
|
||||||
do $$STTYF /dev/tty >/dev/null 2>/dev/null && break ; \
|
do $$STTYF /dev/tty >/dev/null 2>/dev/null && break ; \
|
||||||
done ;\
|
done ;\
|
||||||
$$STTYF $(ARD_PORT) hupcl ;\
|
$$STTYF $(call get_arduino_port) hupcl ;\
|
||||||
(sleep 0.1 || sleep 1) ;\
|
(sleep 0.1 || sleep 1) ;\
|
||||||
$$STTYF $(ARD_PORT) -hupcl
|
$$STTYF $(call get_arduino_port) -hupcl
|
||||||
|
|
||||||
ispload: $(TARGET_HEX)
|
ispload: $(TARGET_EEP) $(TARGET_HEX) verify_size
|
||||||
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ISP_OPTS) -e \
|
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ISP_OPTS) -e \
|
||||||
-U lock:w:$(ISP_LOCK_FUSE_PRE):m \
|
-U lock:w:$(ISP_LOCK_FUSE_PRE):m \
|
||||||
-U hfuse:w:$(ISP_HIGH_FUSE):m \
|
-U hfuse:w:$(ISP_HIGH_FUSE):m \
|
||||||
-U lfuse:w:$(ISP_LOW_FUSE):m \
|
-U lfuse:w:$(ISP_LOW_FUSE):m \
|
||||||
-U efuse:w:$(ISP_EXT_FUSE):m
|
-U efuse:w:$(ISP_EXT_FUSE):m
|
||||||
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ISP_OPTS) -D \
|
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ISP_OPTS) -D \
|
||||||
-U flash:w:$(TARGET_HEX):i
|
$(AVRDUDE_ISPLOAD_OPTS)
|
||||||
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ISP_OPTS) \
|
$(AVRDUDE) $(AVRDUDE_COM_OPTS) $(AVRDUDE_ISP_OPTS) \
|
||||||
-U lock:w:$(ISP_LOCK_FUSE_POST):m
|
-U lock:w:$(ISP_LOCK_FUSE_POST):m
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
$(REMOVE) $(LOCAL_OBJS) $(CORE_OBJS) $(LIB_OBJS) $(CORE_LIB) $(TARGETS) $(DEP_FILE) $(DEPS) $(USER_LIB_OBJS)
|
$(REMOVE) $(LOCAL_OBJS) $(CORE_OBJS) $(LIB_OBJS) $(CORE_LIB) $(TARGETS) $(DEP_FILE) $(DEPS) $(USER_LIB_OBJS) ${OBJDIR}
|
||||||
|
|
||||||
depends: $(DEPS)
|
depends: $(DEPS)
|
||||||
cat $(DEPS) > $(DEP_FILE)
|
$(CAT) $(DEPS) > $(DEP_FILE)
|
||||||
|
|
||||||
size: $(OBJDIR) $(TARGET_ELF)
|
size: $(OBJDIR) $(TARGET_HEX)
|
||||||
$(SIZE) -C --mcu=$(MCU) $(TARGET_ELF)
|
$(call avr_size,$(TARGET_ELF),$(TARGET_HEX))
|
||||||
|
|
||||||
show_boards:
|
show_boards:
|
||||||
$(PARSE_BOARD_CMD) --boards
|
$(PARSE_BOARD_CMD) --boards
|
||||||
|
|
||||||
monitor:
|
monitor:
|
||||||
$(MONITOR_CMD) $(ARD_PORT) $(MONITOR_BAUDRATE)
|
$(MONITOR_CMD) $(call get_arduino_port) $(MONITOR_BAUDRATE)
|
||||||
|
|
||||||
.PHONY: all clean depends upload raw_upload reset reset_stty size show_boards monitor
|
disasm: $(OBJDIR)/$(TARGET).lss
|
||||||
|
@$(ECHO) The compiled ELF file has been disassembled to $(OBJDIR)/$(TARGET).lss
|
||||||
|
|
||||||
include $(DEP_FILE)
|
symbol_sizes: $(OBJDIR)/$(TARGET).sym
|
||||||
|
@$(ECHO) A symbol listing sorted by their size have been dumped to $(OBJDIR)/$(TARGET).sym
|
||||||
|
|
||||||
|
$(TARGET_HEX).sizeok: $(TARGET_HEX)
|
||||||
|
$(ARDMK_PATH)/ard-verify-size $(TARGET_HEX) $(HEX_MAXIMUM_SIZE)
|
||||||
|
touch $@
|
||||||
|
|
||||||
|
verify_size: $(TARGET_HEX) $(TARGET_HEX).sizeok
|
||||||
|
|
||||||
|
generated_assembly: $(OBJDIR)/$(TARGET).s
|
||||||
|
@$(ECHO) Compiler-generated assembly for the main input source has been dumped to $(OBJDIR)/$(TARGET).s
|
||||||
|
|
||||||
|
.PHONY: all upload raw_upload reset reset_stty ispload clean depends size show_boards monitor disasm symbol_sizes generated_assembly verify_size
|
||||||
|
|
||||||
|
# added - in the beginning, so that we don't get an error if the file is not present
|
||||||
|
ifneq ($(MAKECMDGOALS),clean)
|
||||||
|
-include $(DEP_FILE)
|
||||||
|
endif
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
#! /usr/bin/perl
|
#! /usr/bin/env perl
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
@ -8,9 +8,14 @@ use Pod::Usage;
|
||||||
use YAML;
|
use YAML;
|
||||||
|
|
||||||
my %Opt =
|
my %Opt =
|
||||||
(
|
(
|
||||||
boards_txt => '/Applications/Arduino.app/Contents/Resources/Java/hardware/arduino/boards.txt',
|
boards_txt => '/Applications/Arduino.app/Contents/Resources/Java/hardware/arduino/boards.txt',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
# if the ARDUINO_DIR is defined, then use it
|
||||||
|
if (defined $ENV{'ARDUINO_DIR'}) {
|
||||||
|
$Opt{boards_txt} = "$ENV{'ARDUINO_DIR'}/hardware/arduino/boards.txt";
|
||||||
|
}
|
||||||
|
|
||||||
GetOptions(\%Opt,
|
GetOptions(\%Opt,
|
||||||
"boards_txt=s", # filename of the boards.txt file
|
"boards_txt=s", # filename of the boards.txt file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
#! /usr/bin/perl
|
#! /usr/bin/env perl
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
|
|
@ -3,6 +3,9 @@
|
||||||
import sys
|
import sys
|
||||||
import serial
|
import serial
|
||||||
|
|
||||||
ser = serial.Serial(sys.argv[1], 1200)
|
ser = serial.Serial(sys.argv[1], 57600)
|
||||||
|
s.open()
|
||||||
|
s.close()
|
||||||
|
s.setBaudrate(1200)
|
||||||
ser.open()
|
ser.open()
|
||||||
ser.close()
|
ser.close()
|
||||||
|
|
9
bin/ard-verify-size
Executable file
9
bin/ard-verify-size
Executable file
|
@ -0,0 +1,9 @@
|
||||||
|
#!/bin/bash
|
||||||
|
TARGET_HEX="$1"
|
||||||
|
MAX_SIZE="$2"
|
||||||
|
HEX_SIZE="$(cut -c12- < $TARGET_HEX | tr -d \\n | tr -d \\r | wc -c | awk '{print $1/2}')"
|
||||||
|
if [ $HEX_SIZE -gt $MAX_SIZE ]
|
||||||
|
then
|
||||||
|
echo "Sketch size is ${HEX_SIZE} bytes and maximum allowed is ${MAX_SIZE} bytes; see http://www.arduino.cc/en/Guide/Troubleshooting#size for tips on reducing it." 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
BIN
examples/BlinkWithoutDelay/.DS_Store
vendored
BIN
examples/BlinkWithoutDelay/.DS_Store
vendored
Binary file not shown.
Loading…
Reference in a new issue