From ca7ecf658f0085ad72732e27a9110b7060d91188 Mon Sep 17 00:00:00 2001 From: jeditekunum Date: Sat, 31 Jan 2015 13:32:31 -0600 Subject: [PATCH] Update README for MoteinoMEGA (ATMEGA1284P) port. --- configs/moteino-mega/README.txt | 321 ++++++-------------------------- 1 file changed, 53 insertions(+), 268 deletions(-) diff --git a/configs/moteino-mega/README.txt b/configs/moteino-mega/README.txt index 97b1e08dcb..6cf9330db6 100644 --- a/configs/moteino-mega/README.txt +++ b/configs/moteino-mega/README.txt @@ -1,9 +1,7 @@ README ^^^^^^ -********************************************************************** -**** PRELIMINARY - Port in progress **** -********************************************************************** +This port conributed by jeditekunum. This is the README file for the port of NuttX to the MoteinoMEGA from LowPowerLab (http://www.lowpowerlab.com). The MoteinoMEGA is based @@ -19,9 +17,6 @@ Contents o Pin Connections o DualOptiboot Bootloader o Toolchains - o Windows Native Toolchains - o NuttX buildroot Toolchain - o avr-libc o MoteinoMEGA Configuration Options o Configurations @@ -35,83 +30,62 @@ MoteinoMEGA Features o 2 High Speed Serial Ports o 8Ch 10bit Analog Input port -Pin Connections (PCB Rev ?) -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +Pin Connections +^^^^^^^^^^^^^^^ -------------------- ----------------------------- ATMega1284P Pinout MoteinoMEGA board connection -------------------- ----------------------------- -********************************************************************** -**** INVALID - Port in progress **** -********************************************************************** (left) - 1 PEN Pulled-up - 2 PE0 (RXD0/PDI) MAX202ECWED T1IN or J7-1, ISP-PDI (via 74HC5053), J5-26 - 3 PE1 (TXD0/PDO) MAX202ECWED A1OUT or J7-9, ISP-PDO (via 74HC5053), J5-25 - 4 PE2 (XCK0/AIN0) MAX202ECWED T2IN, J5-24 - 5 PE3 (OC3A/AIN1) MAX202ECWED A2OUT, J5-23 - 6 PE4 (OC3B/INT4) J5-22 - 7 PE5 (OC3C/INT5) J5-21, RTL8019AS INT 0, TP5 PE5 - 8 PE6 (T3/INT6) J5-20 - 9 PE7 (ICP3/INT7) J5-19 - 10 PB0 (SS) Pull up of SS SPI master - 11 PB1 (SCK) J7-7, ISP_SCK (via 74HC4053) and AT45D011 SCK, J5-17 - 12 PB2 (MOSI) AT45D011 SI. J5-16 - 13 PB3 (MISO) AT45D011 SO, J5-15 - 14 PB4 (OC0) AT45D011 CS\, J5-14 - 15 PB5 (OC1A) J5-13 - 16 PB6 (OC1B) J5-12 + 1 AREF AR + 2 PA7 A7 + 3 PA6 A6 + 4 PA5 A5 + 5 PA4 A4 + 6 PA3 A3 + 7 PA2 A2 + 8 PA1 A1 + 9 PA0 A0 + 10 PB0 0 + 11 PB1 1 + 12 PB2 (INT2) 2/i2 (used by optional radio) + 13 PB3 (PWM0) 3 + 14 PB4 (PWM1/SS) 4/SS (used by optional radio) + 15 PB5 (MOSI) 5/MO (used by optional radio/flash) + 16 PB6 (MISO/PWM2) 6/MI (used by optional radio/flash) + 17 PB7 (SCK/PWM3) 7/SCK (used by optional radio/flash) + 18 VOUT 3v3 + 19 VIN VIN + 20 GND GND (bottom) - 17 PB7 (OC2/OC1C) J5-11 - 18 PG3/TOSC2 32.768KHz XTAL - 19 PG4/TOSC1 32.768KHz XTAL - 20 RESET RESET - 21 VCC - 22 GND GND - 23 XTAL2 14.7456MHz XTAL - 24 XTAL1 14.7456MHz XTAL - 25 PD0 (SCL/INT0) J5-10 - 26 PD1 (SDA/INT1) J5-9 - 27 PD2 (RXD1/INT2) J5-8, MAX488CSA RO (RS-485) - 28 PD3 (TXD1/INT3) J5-7, MAX488CSA DI (RS-485) - 29 PD4 (ICP1) J5-6 - 30 PD5 (XCK1) J5-5 - 31 PD6 (T1) J5-4 - 32 PD7 (T2) J5-3 - (left) - 48 PA3 (AD3) J5-?, 74HC5730, 62246DLP-7, RTL8019AS - 47 PA4 (AD4) J5-?, 74HC5730, 62246DLP-7, RTL8019AS - 46 PA5 (AD5) J5-?, 74HC5730, 62246DLP-7, RTL8019AS - 45 PA6 (AD6) J5-?, 74HC5730, 62246DLP-7, RTL8019AS - 44 PA7 (AD7) J5-?, 74HC5730, 62246DLP-7, RTL8019AS - 43 PG2 (ALE) J5-1, 74HC5730, 62246DLP-7, RTL8019AS - 42 PC7 (A15) TP4 A15, J5-27, 74HC5730 - 41 PC6 (A14) J5-28, 74HC5730, 62246DLP-7, RTL8019AS - 40 PC5 (A13) J5-29, 74HC5730, 62246DLP-7, RTL8019AS - 39 PC4 (A12) J5-30, 74HC5730, 62246DLP-7, RTL8019AS - 38 PC3 (A11) J5-31, 74HC5730, 62246DLP-7, RTL8019AS - 37 PC2 (A10) J5-32, 74HC5730, 62246DLP-7, RTL8019AS - 36 PC1 (A9) J5-33, 74HC5730, 62246DLP-7, RTL8019AS - 35 PC0 (A8) J5-34, 74HC5730, 62246DLP-7, RTL8019AS - 34 PG1 (RD) TP2 RD\, J5-52, 62246DLP-7, RTL8019AS - 33 PG0 (WR) TP3 WR\, J5-51, 62246DLP-7, RTL8019AS - (top) - 64 AVCC - 63 GND GND - 62 AREF (analog supply) - 61 PF0 (ADC0) J6-5, PDV-P9 Light Sensor - 60 PF1 (ADC1) J6-7, Thermister - 59 PF2 (ADC2) J6-9, MXA2500GL Dual Axis Accesserometer, AOUTX - 58 PF3 (ADC3) J6-11, MXA2500GL Dual Axis Accesserometer, AOUTY - 57 PF4 (ADC4/TCK) J6-13, MXA2500GL Dual Axis Accesserometer, TOUT - 56 PF5 (ADC5/TMS) J6-15 - 55 PF6 (ADC6/TDO) J6-17 - 54 PF7 (ADC7/TDI) J6-19 - 53 GND GND - 52 VCC - 51 PA0 (AD0) J5-?, 74HC5730, 62246DLP-7, RTL8019AS - 50 PA1 (AD1) J5-?, 74HC5730, 62246DLP-7, RTL8019AS - 49 PA2 (AD2) J5-?, 74HC5730, 62246DLP-7, RTL8019AS + 21 DTR/RTS DTR + 22 TX0 v + 23 RX0 ^ + 24 VIN + 25 + 26 GND GND + (right) + 27 GND GND + 28 VIN VIN + 29 VOUT 3v3 + 30 RESET RST + 31 PD0 (RX0) 8/Serial 0 ^ + 32 PD1 (TX0) 9/Serial 0 v + 33 PD2 (RX1/INT0) 10/Serial 0 ^/i0 + 34 PD3 (TX1/INT1) 11/Serial 1 v/i1 + 35 PD4 (PWM4) 12 + 36 PD5 (PWM5) 13 + 37 PD6 (PWM6) 14 + 38 PD7 (PWM7) 15/LED + 39 PC0 (SCL) 16/SCL + 40 PC1 (SDA) 17/SDA + 41 PC2 (TCK) 18 + 42 PC3 (TMS) 19 + 43 PC4 (TDO) 20 + 44 PC5 (TDI) 21 + 45 PC6 22 + 46 PC7 23 (used by optional flash) + DualOptiboot Bootloader ^^^^^^^^^^^^^^^^^^^^^^^ @@ -149,183 +123,8 @@ the toolchain on the make commandline with CONFIG_AVR_TOOLCHAIN=. The valid values for are BUILDROOT, CROSSPACK, LINUXGCC and WINAVR. -Buildroot: - - There is a DIY buildroot version for the AVR boards here: - http://sourceforge.net/projects/nuttx/files/buildroot/. See the - following section for details on building this toolchain. - - It is assumed in some places that buildroot toolchain is available - at ../misc/buildroot/build_avr. Edit the setenv.sh file if - this is not the case. - - After configuring NuttX, make sure that CONFIG_AVR_BUILDROOT=y is set in your - .config file. - -WinAVR: - - For Cygwin development environment on Windows machines, you can use - WinAVR: http://sourceforge.net/projects/winavr/files/ - - It is assumed in some places that WinAVR is installed at C:/WinAVR. Edit the - setenv.sh file if this is not the case. - - After configuring NuttX, make sure that CONFIG_AVR_WINAVR=y is set in your - .config file. - - WARNING: There is an incompatible version of cygwin.dll in the WinAVR/bin - directory! Make sure that the path to the correct cygwin.dll file precedes - the path to the WinAVR binaries! - -Linux: - - For Linux, there are widely available avr-gcc packages. On Ubuntu, use: - sudo apt-get install gcc-avr gdb-avr avr-libc - - After configuring NuttX, make sure that CONFIG_AVR_LINUXGCC=y is set in your - .config file. - -Mac OS X: - - For Mac OS X, the CrossPack for AVR toolchain is available from: - - http://www.obdev.at/products/crosspack/index.html - - This toolchain is functionally equivalent to the Linux GCC toolchain. - -Windows Native Toolchains -^^^^^^^^^^^^^^^^^^^^^^^^^ - - The WinAVR toolchain is a Windows native toolchain. There are several - limitations to using a Windows native toolchain in a Cygwin environment. - The three biggest are: - - 1. The Windows toolchain cannot follow Cygwin paths. Path conversions are - performed automatically in the Cygwin makefiles using the 'cygpath' - utility but you might easily find some new path problems. If so, check - out 'cygpath -w' - - 2. Windows toolchains cannot follow Cygwin symbolic links. Many symbolic - links are used in Nuttx (e.g., include/arch). The make system works - around these problems for the Windows tools by copying directories - instead of linking them. But this can also cause some confusion for - you: For example, you may edit a file in a "linked" directory and find - that your changes had no effect. That is because you are building the - copy of the file in the "fake" symbolic directory. If you use a - Windows toolchain, you should get in the habit of making like this: - - make clean_context all - - An alias in your .bashrc file might make that less painful. - - 3. Dependencies are not made when using Windows versions of the GCC. This - is because the dependencies are generated using Windows pathes which do - not work with the Cygwin make. - - MKDEP = $(TOPDIR)/tools/mknulldeps.sh - - An additional issue with the WinAVR toolchain, in particular, is that it - contains an incompatible version of the Cygwin DLL in its bin/ directory. - You must take care that the correct Cygwin DLL is used. - -NuttX buildroot Toolchain -^^^^^^^^^^^^^^^^^^^^^^^^^ - - If NuttX buildroot toolchain source tarball cne can be downloaded from the - NuttX SourceForge download site (https://sourceforge.net/projects/nuttx/files/). - This GNU toolchain builds and executes in the Linux or Cygwin environment. - - 1. You must have already configured Nuttx in /nuttx. - - cd tools - ./configure.sh amber/ - - NOTE: you also must copy avr-libc header files into the NuttX include - directory with command perhaps like: - - cp -a /cygdrive/c/WinAVR/include/avr include/. - - 2. Download the latest buildroot package into - - 3. unpack the buildroot tarball. The resulting directory may - have versioning information on it like buildroot-x.y.z. If so, - rename /buildroot-x.y.z to /buildroot. - - 4. cd /buildroot - - 5. cp configs/avr-defconfig-4.5.2 .config - - 6. make oldconfig - - 7. make - - 8. Edit setenv.h, if necessary, so that the PATH variable includes - the path to the newly built binaries. - - See the file configs/README.txt in the buildroot source tree. That has more - detailed PLUS some special instructions that you will need to follow if you - are building a toolchain for Cygwin under Windows. - -avr-libc -^^^^^^^^ - -Header Files - - In any case, header files from avr-libc are required: http://www.nongnu.org/avr-libc/. - A snapshot of avr-lib is included in the WinAVR installation. For Linux - development platforms, avr-libc package is readily available (and would - be installed in the apt-get command shown above). But if you are using - the NuttX buildroot configuration on Cygwin, then you will have to build - get avr-libc from binaries. - -Header File Installation - - The NuttX build will required that the AVR header files be available via - the NuttX include directory. This can be accomplished by either copying - the avr-libc header files into the NuttX include directory: - - cp -a /include/avr /include/. - - Or simply using a symbolic link: - - ln -s /include/avr /include/. - -Build Notes: - - It may not necessary to have a built version of avr-lib; only header files - are required. Bu if you choose to use the optimized libraru functions of - the flowing point library, then you may have to build avr-lib from sources. - Below are instructions for building avr-lib from fresh sources: - - 1. Download the avr-libc package from: - - http://savannah.nongnu.org/projects/avr-libc/ - - I am using avr-lib-1.7.1.tar.bz2 - - 2. Upack the tarball and cd into the - - tar jxf avr-lib-1.7.1.tar.bz2 - cd avr-lib-1.7.1 - - 3. Configure avr-lib. Assuming that WinAVR is installed at the following - loction: - - export PATH=/cygdrive/c/WinAVR/bin:$PATH - ./configure --build=`./config.guess` --host=avr - - This takes a *long* time. - - 4. Make avr-lib. - - make - - This also takes a long time because it generates variants for nearly - all AVR chips. - - 5. Install avr-lib. - - make install +This port was tested using the OS X / CROSSPACK tool chain, GCC version 4.8.1. +Please see other NuttX documentation for toolchain details. MoteinoMEGA Configuration Options ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ @@ -364,9 +163,6 @@ MoteinoMEGA Configuration Options CONFIG_ARCH_LOOPSPERMSEC - Must be calibrated for correct operation of delay loops - CONFIG_ENDIAN_BIG - define if big endian (default is little - endian) - CONFIG_RAM_SIZE - Describes the installed DRAM. One of: CONFIG_RAM_SIZE=(16*1024) - (16Kb) @@ -460,10 +256,6 @@ Common Configuration Notes Where is one of the configuration sub-directories described in the following paragraph. - NOTE: You must also copy avr-libc header files, perhaps like: - - cp -a /cygdrive/c/WinAVR/include/avr include/. - 2. These configurations use the mconf-based configuration tool. To change a configurations using that tool, you should: @@ -473,13 +265,6 @@ Common Configuration Notes b. Execute 'make menuconfig' in nuttx/ in order to start the reconfiguration process. - 3. By default, all configurations assume the NuttX Buildroot toolchain - under Cygwin with Windows. This is easily reconfigured: - - CONFIG_HOST_WINDOWS=y - CONFIG_WINDOWS_CYGWIN=y - CONFIG_AVR_BUILDROOT=y - Configuration Sub-Directories -----------------------------