summaryrefslogtreecommitdiff
path: root/nuttx/configs/16z/README.txt
blob: 03338ada6f1a9883a8a91807cb457f21afb90efb (plain) (blame)
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
README.txt
==========

This is the README file for the NuttX port to the 16z board. The 16z board
is based on the ZiLOG ZNEOZ16F2811AL20EG part.  See https://github.com/toyaga/16z
for further information.

Contents
========

  - GPIO Configuration
  - ZDS-II Compiler Versions
  - Patches
  - Serial Console
  - LEDs
  - RAM
  - Selecting Configurations
  - Configuration Sub-directories

GPIO Configuration
==================

  --------------------------- ------ --------------------------------------------
  GPIO                        SIGNAL On-Board Connections
  --------------------------- ------ --------------------------------------------
  PA0/T0IN/T0OUT/DMA0REQ      GP8    PS/2 / GPIO, Expansion slots
  PA1/T0OUT/DMA0ACK           GP9    PS/2 / GPIO, Expansion slots
  PA2/DE0/FAULTY              ~INTI  Power section, RF transceiver (1)
  PA3/CTS0/FAULT0             ~INTX  Expansion slots
  PA4/RXD0/CS1                RXD    MAX3232D RS-232
  PA5/TXD0/CS2                TXD    MAX3232D RS-232
  PA6/SCL/CS3                 SCL    RTC / UID, Expansion slots
  PA7/SDA/CS4                 SDA    RTC / UID, Expansion slots
  --------------------------- ------ --------------------------------------------
  PB0/ANA0/T0IN0              GP0    Expansion slots
  PB1/ANA1/T0IN1              GP1    Expansion slots
  PB2/ANA2/T0IN2              GP2    Expansion slots
  PB3/ANA3/OPOUT              GP3    Expansion slots
  PB4/ANA4                    GP4    Expansion slots
  PB5/ANA5                    GP5    Expansion slots
  PB6/ANA6/OPINP/CINN         GP6    Expansion slots
  PB7/ANA7/OPINN              GP7    Expansion slots
  --------------------------- ------ --------------------------------------------
  PC0/T1IN/T1OUT/DMA1REQ/CINN GP10   PS/2 / GPIO, Expansion slots
  PC1/T1OUT/DMA1ACK/COMPOUT   GP11   PS/2 / GPIO, Expansion slots
  PC2/SS/CS4                  ~EXP   Expansion slots
  PC3/SCK/DMA2REQ             SCK    FT800Q, Serial memory (1), RF Transceiver (1),
                                     Expansion slots, SD0, 1, and 2
  PC4/MOSI/DMA2ACK            MOSI   FT800Q, Serial memory (1), RF Transceiver (1),
                                     Expansion slots, SD0, 1, and 2
  PC5/MISO/CS5                MISO   FT800Q, Serial memory (1), RF Transceiver (1),
                                     Expansion slots, SD0, 1, and 2
  PC6/T2IN/T2OUT/PWMH0        ~CTS   MAX3232D RS-232
  PC7/T2OUT/PWML0             ~RTS   MAX3232D RS-232, Power section (?)
  --------------------------- ------ --------------------------------------------
  PD0/PWMH1/ADR20             A20    RAM, Expansion slots
  PD1/PWML1/ADR21             A21    RAM, Expansion slots
  PD2/PWMH2/ADR22             A22    RAM, Expansion slots
  PD3/DE1/ADR16               A16    RAM, Expansion slots
  PD4/RXD1/ADR18              A18    RAM, Expansion slots
  PD5/TXD1/ADR19              A19    RAM, Expansion slots
  PD6/CTS1/ADR17              A17    RAM, Expansion slots
  PD7/PWML2/ADR23             A23    Expansion slots
  --------------------------- ------ --------------------------------------------
  PE0/DATA0                   D0     RAM, Expansion slots
  PE1/DATA1                   D1     RAM, Expansion slots
  PE2/DATA2                   D2     RAM, Expansion slots
  PE3/DATA3                   D3     RAM, Expansion slots
  PE4/DATA4                   D4     RAM, Expansion slots
  PE5/DATA5                   D5     RAM, Expansion slots
  PE6/DATA6                   D6     RAM, Expansion slots
  PE7/DATA7                   D7     RAM, Expansion slots
  --------------------------- ------ --------------------------------------------
  PF0/ADR0                    A0     Expansion slots
  PF1/ADR1                    A1     RAM, Expansion slots
  PF2/ADR2                    A2     RAM, Expansion slots
  PF3/ADR3                    A3     RAM, Expansion slots
  PF4/ADR4                    A4     RAM, Expansion slots
  PF5/ADR5                    A5     RAM, Expansion slots
  PF6/ADR6                    A6     RAM, Expansion slots
  PF7/ADR7                    A7     RAM, Expansion slots
  --------------------------- ------ --------------------------------------------
  PG0/ADR0                    A8     RAM, Expansion slots
  PG1/ADR0                    A9     RAM, Expansion slots
  PG2/ADR0                    A10    RAM, Expansion slots
  PG3/ADR0                    A11    RAM, Expansion slots
  PG4/ADR0                    A12    RAM, Expansion slots
  PG5/ADR0                    A13    RAM, Expansion slots
  PG6/ADR0                    A14    RAM, Expansion slots
  PG7/ADR0                    A15    RAM, Expansion slots
  --------------------------- ------ --------------------------------------------
  PH0/ANA8/WR                 ~WR    RAM, Expansion slots
  PH1/ANA9/RD                 ~RD    RAM, Expansion slots
  PH2/ANA10/CS0               ~RF    LED3, RF transceiver, X2 (1)
  PH3/ANA11/CINP/WAIT         ~SXM   LED4, Chip select for the serial memory, U4 (1)
  --------------------------- ------ --------------------------------------------
  PJ0/DATA8                   ~SD1   LED5, Chip select for the SD card 1, X11.
  PJ1/DATA9                   ~DT1   Card detect for SD card 1
  PJ2/DATA10                  WP1    Write protect for SD card 1
  PJ3/DATA11                  EVE    EVE chip select
  PJ4/DATA12                  ~SD2   LED6, Chip select for the SD card 2, X10.
  PJ5/DATA13                  ~DT2   Card detect for SD card 2
  PJ6/DATA14                  WP2    Write protect for SD card 2
  PJ7/DATA15                  ~SD0   LED7, Chip select for the microSD 0, X12.
  --------------------------- ------ --------------------------------------------
  PK0/BHEN                    ~BHE   RAM, Expansion slots
  PK1/BLEN                    ~BLE   RAM, Expansion slots
  PK2/CS0                     ~0000  Bottom RAM bank, Expansion slots
  PK3/CS1                     ~8000  Top RAM bank, Expansion slots
  PK4/CS2                     ~F000  Expansion slots
  PK5/CS3                     ~FFC8  Expansion slots
  PK6/CS4                     ~FFD0  Expansion slots
  PK7/CS5                     ~FFD8  Expansion slots
  --------------------------- ------ --------------------------------------------

  Note 1:  Not populated on my board

ZDS-II Compiler Versions
========================

Version 5.0.1

  All testing has been performed with ZSD II verion 5.0.1 for the ZNEO.

  There are some problems with this compiler version.  See the section
  entitled "Patches" below.

Other Versions

  If you use any version of ZDS-II other than 5.0.1 or if you install ZDS-II
  at any location other than the default location, you will have to modify
  two files:  (1) configs/16z/*/setenv.sh and (2) configs/16z/*/Make.defs.
  Simply edit these two files, changing 5.0.1 to whatever.

Patches
=======

A bug has been found in the ZDS-II toolchain version 5.0.1.  a patch is
available to work around the bug.  A summary of the nature the bug and
instructions for applying the patch follow.

Parameters are passed different to variadic functions (i.e., functions
that accept a varying number of parameters) than to regular functions.  For
most functions, parameters are passed in registers, beginning with R1.  But
for variadic functions, all parameters must be passed on the stack.

The logic works correctly for global functions, local functions, and most
function pointers.  It does not work correctly for the case where a variadic
function point is included within a structure.  In that case, the caller
inappropriately passes the parameters in registers; the receiver will
attempt to recover the parameters from the stack and a failure then follows.

This bug prevents the use of NSH with the ZNEO.  However, a patch has been
developed that works around the problem.  That patch can be found at
configs/16z/tools/zneo-zdsii-5_0_1-variadic-func-fix.patch.  In that
directory is also a bash script that will apply that patch for you.

The patch would be applied when NuttX is configured as follows:

  cd tools
  ./configure.sh 16z/nsh
  cd ..
  . ./setenv.sh
  dopatch.sh
  make

The patch can also be removed with:

  dopatch.sh -R

See the section "Selecting Configurations" below.

UPDATE:  2014-4-27:  The nsh example still does not run correctly.  This
is believe to be caused by additional, undiagnosed compiler errors.

Serial Console
==============

The 16z supports a single UART, UART0, that will be used to support the
NuttX serial console.

LEDs
====

The 16z board has 7 LEDs, five of which are controllable via software:

  ----- ------ ------ ------------------------------------
  LED   Color  Signal Description
  ----- ------ ------ ------------------------------------
  LED1  Red     3V3   Indicates the presence of +3.3V
  LED2  Red     5V    Indicates the presence of +5V

  LED3  Blue    ~RF   Controlled via PH2.  Notes: 1, 2
  LED4  Green   ~SXM  Controlled via PH3.  Notes: 1, 3
  LED5  Green   ~SD1  Controlled via PJ0.  Notes: 1, 4
  LED6  Yellow  ~SD2  Controlled via PJ4.  Notes: 1, 5
  LED7  Yellow  ~SD0  Controlled via PJ7.  Notes: 1, 6
  ----- ------ ------ ------------------------------------

  Note 1:  Pulled high so a low output illuminates the LED.
  Note 2:  PH2/~RF is also used by the RF transceiver, X2.  That part is not
           populated on my board.
  Note 3:  ~SXM is the chip select for the serial memory, U4.  That part is
           not populated on my board.
  Note 4:  ~SD1 is the chip select for the SD card 1, X11.
  Note 5:  ~SD2 is the chip select for the SD card 2, X10.
  Note 6:  ~SD0 is the chip select for the microSD 0, X12.

In conclusion:  None of the LEDs are available to indicate software status
without potentially sacrificing board functionality.  If the RF transceiver
is not installed (CONFIG_16Z_RFTRANSCEIVER=n) and if LED support is
requested (CONFIG_ARCH_LEDS), then LED3 will be used to indicate status:  A
solid color means that the board has boot successfully; flashing at a rate
of approximately 2Hz indicates a software failure.

RAM
===

The 16z has two IS66WVE4M16BLL 64Mb (4M x 16b) "Pseudo" SRAM parts on board.
This provides a total of 16MiB of SRAM from program usage.

Selecting Configurations
========================

Variations on the basic 16z configuration are maintained in subdirectories.
To configure any specific configuration, do the following steps:

   cd <nuttx-top-directory>/tools
   ./configure.sh 16z/<sub-directory>
   cd <nuttx-top-directory>
   make

Where <sub-directory> is the specific board configuration that you wish to
build.  The following board-specific configurations are available.  You may
also need to apply a path to NuttX before making.  Please refer the the
section "Patches" above"

Before entering the make command, make certain that the path to the ZNEO
compiler is in you PATH variable.  You make modify and use the setenv.sh
script to set that PATH if you like.  You can simply source setenv.sh
before making like:

  ...
  . ./setenv.sh
  make

Configuration Sub-directories
=============================

source/ and include/
--------------------

  These directories contain common logic for all 16z configurations.

nsh
---
  nsh:
    This configuration directory will built the NuttShell (NSH).  See
    the NSH user manual in the documents directory (or online at nuttx.org).
    See also the README.txt file in the nsh sub-directory for information
    about using ZDS-II.

    NOTES:

    1. This configuration uses the mconf-based configuration tool.  To
       change this configuration using that tool, you should:

       a. Build and install the kconfig-mconf tool.  See nuttx/README.txt
          and misc/tools/

       b. Execute 'make menuconfig' in nuttx/ in order to start the
          reconfiguration process.

    2. By default, this configuration assumes that you are using the
       Cygwin environment on Windows.  An option is to use the native
       CMD.exe window build as described in the top-level README.txt
       file.  To set up that configuration:

       -CONFIG_WINDOWS_CYGWIN=y
       +CONFIG_WINDOWS_NATIVE=y

       And after configuring, make sure that CONFIG_APPS_DIR uses
       the back slash character.  For example:

        CONFIG_APPS_DIR="..\apps"

    3. By default, this configuration assumes that you are using the
       Cygwin environment on Windows.  An option is to use the native
       CMD.exe window build as described in the top-level README.txt
       file.  To set up that configuration:

       -CONFIG_WINDOWS_CYGWIN=y
       +CONFIG_WINDOWS_NATIVE=y

       And after configuring, make sure that CONFIG_APPS_DIR uses
       the back slash character.  For example:

        CONFIG_APPS_DIR="..\apps"

      NOTES:

      a. If you need to change the toolchain path used in Make.defs, you
         will need to use the short 8.3 filenames to avoid spaces.  On my
         PC, C:\PROGRA~1\ is is C:\Program Files\ and C:\PROGRA~2\ is
         C:\Program Files (x86)\
      b. You can't use setenv.sh in the native Windows environment.  Try
         scripts/setenv.bat instead.
      c. At present, the native Windows build fails at the final link stages.
         The failure is due to problems in arch/z16/src/nuttx.linkcmd that
         is autogenerated by arch/z16/src/Makefile.  The basic problem
         is the spurious spaces and and carrirage returns are generated at
         the end of the lines after a line continuation (\ ^M).  If these
         trailing bad characters are manually eliminated, then the build
         will succeed on the next try.

   STATUS:

     1. Note that you must apply the ZNEO patch if you are using ZDS-II 5.0.1.
        See the README.txt file in the parent directory for more information.

     2. This configuration does not run correctly.  This is believed to a yet
        another ZDS-II compiler problem.  The corresponding NSH configuration
        of the z16f2800100zcog does work, however, so this could also be an
        issue with the 16z.

Check out any README.txt files in these <sub-directory>s.