No part of the contents of this manual may be reproduced or transmitted in any form or by any means
without the express written permission of Digi International.
Permission is granted to make one or more copies as long as the copyright page contained therein is
included. These copies of the manuals may not be let or sold for any reason without the express written
permission of Digi International.
Digi International reserves the right to make changes and
improvements to its products without providing n otice.
T r ade mark s
Rabbit, MiniCore, and Dynamic C are registered trademarks of Digi International Inc.
Wi-Fi is a registered trademark of the Wi-Fi Alliance.
Rabbit 5000 and MiniCore are trademarks of Digi International Inc.
The latest revision of this manual is available on the Rabbit Web s ite, www.rabb it.com,
for free, unregistered download.
4.4.1 Standalone Operation of the RCM5600W..................................................................................35
4.5 Other Hardware...................................................................................................................................36
B.3 Power Supply.....................................................................................................................................86
B.4 Using the Interface Board..................................................................................................................87
The RCM5600W MiniCore modu le provides a compact mod ule in
a mini PCI Express form factor with integrated Wi-Fi/802.11b/g
functionality to allow you t o create a low-co st, low-power, Wi-Fi
based control and communications solution for your embedded
system.
A Development Kit is available with the essentials that you need
to design your own microprocessor-based system, and includes
a complete Dynamic C software development system. The
Development Kit also contains an Interface Board with a USB
connection that will allow you to evaluate the RCM 5600W, and
a Prototyping Board to help you to develop your own applications. You will also be able to write and test software for the
RCM5600W modules, including Wi-Fi applications.
The RCM5600W has a Rabbit 5000 microprocessor operating at up to 73.73 MHz, flash
memory, two clocks (main oscillator and real-time clock), and the circuitry necessary to
reset and manage the Rabbit 5000. An edge connector brings out the RCM5600W user
interface to a 52-pin mini PCI Express socket on the motherboard the RCM5600W is
mounted on.
The RCM5600W receives its +3.3 V power from the motherboard on which it is mounted.
The RCM5600W can interface with other CMOS-compatible digital devices through the
motherboard.
User’s Manual1
1.1 RCM5600W Features
• Small size: 1.20" × 2.00" × 0.40"
(30 mm × 51 mm × 10 mm)
• Microprocessor: Rabbit 5000 running
at 73.73 MHz
• Up to 35 general-purpose I/O lines each configurable with up to four alternate functions
• 3.3 V I/O lines
Six CMOS-compatible serial ports — f
•
our ports are configurable as a clocked serial port
(SPI), and two ports are configurable as SDLC/HDLC serial ports.
• Airoha single-chip 802.11b/g transceiver
• External I/O bus can be configured for 8 data lines, 8 address lines (shared with parallel
I/O lines), and I/O read/write
• 1MB SRAM and 1MB serial flash memory
• Battery-backable real-time clock
• Watchdog supervisor
Currently there is one RCM5600W production model. Table 1 summarizes its main features.
Table 1. RCM5600W Features
FeatureRCM5600W
Microprocessor
Rabbit
®
5000 at 73.73 MHz
SRAM1MB
Serial Flash Memory
(program)
6 shared high-speed, CMOS-compatible ports:
6 are configurable as asynchronous serial ports;
Serial Ports
Wi-Fi802.11b/g standard, ISM 2.4 GHz
4 are configurable as clocked serial ports (SPI);
2 are configurable as SDLC/HDLC serial ports;
1 asynchronous serial port is used during programming
1MB
The RCM5600W is programmed through a USB connector on the motherboard using a
USB cable supplied with th e De vel o pm e n t Ki t.
NOTE: The RabbitLink cannot be used to program the RCM5600W.
Appendix A provides detailed specifications for the RCM5600W.
2MiniCore RCM5600W
1.2 Advantages of the RCM5600W
• Fast time to market using a fully engineered, “ready-to-run/ready-to-program” microprocessor core.
• Competitive pricing when c ompar ed with the alternative of purchasing and assembling
individual components.
• Easy C-language program development and debugging
• Rabbit Field Utility to download compiled Dynamic C .bin files.
• Generous memory size allows large programs with tens of thousands of lines of code,
and substantial data storage.
User’s Manual3
1.3 Development and Evaluation Tools
1.3.1 RCM5600W Standard Development Kit
The RCM5600W Standard Development Kit contains the hardware essentials you will
need to use your RCM5600W module. These items are supplied in the standard version of
the Development Kit.
• RCM5600W module.
• 2.4 GHz dipole antenna with mounting bracket and U.FL to RP-SMA connector cable.
• Interface Board with standoffs/connectors.
• Prototyping Board with standoffs/connectors.
• USB cable to program RCM5600W via Interface Board.
• Dynamic C CD-ROM, including product documentation on disk.
• Getting Started instructions.
• Registration card.
USB Cable
Antenna
CAUTION: Provide ESD protection such as smocks and grounding straps on your footwear
while assembling the RCM5600W module, installing it on another board, and while making or
removing any connections.
MiniCore RCM5600W
The RCM5600W MiniCore module provides a compact module in a mini PCI Express form factor
with integrated Wi-Fi/802.11b/g functionality to allow you to create a low-cost, low-power, Wi-Fi
based control and communications solution for your embedded system. These Getting Started instructions included with the Development Kit will help you get your RCM5600W up and running so that
you can run the sample programs to explore its capabilities and develop your own applications.
Development Kit Contents
The RCM5600W Standard Development Kit contains the following items
• RCM5600W m odule.
• 2.4 GHz dipole antenna with mounting bracket and RP-SMA connector cable.
• Interface Board with standoffs/connectors.
• Prototyping Board with standoffs/connectors.
• USB cable to program RCM5600W via Interface Board.
®
• Dynamic C
CD-ROM, with complete product documentation on disk.
• G etting Started instructions.
• R egistration card.
Visit our online Rabbit store at www.rabbit.com/store/ for the latest information on peripherals and
accessories that are available for the RCM5600W MiniCore modules.
®
Step 1 — Install Dynamic C
Before doing any development, you must install Dynamic C. Insert the CD from the Development Kit
in your PC’s CD-ROM drive. If the installation does not auto-start, run the setup.exe program in
the root directory of the Dynamic C CD. Install any Dynamic C modules after you install Dynamic C
Rabbit, Dynamic C, and Digi are registered trademarks of Digi International Inc.
Getting Started
Instructions
RP-SMA Connector
Cable
IDC Header
Strip
.
Antenna
Bracket
Prototyping Board
Standoffs
Interface Board
Figure 1. RCM5600W Standard Development Kit
1.3.2 RCM5600W Deluxe Development Kit
In addition to the items included in the standard Development Kit, the Deluxe Development Kit contains the following items.
• Universal AC adapter, 5 V DC, 2 A (includes Canada/Japan/U.S., Australia/N.Z., U.K.,
and European style plugs). Development Kits sold in North America may contain an
AC adapter with only a North American style plug.
• Digital I/O and Serial Communication accessory boards for use with certain sample
programs.
• DB9 to 10-pin header serial cable.
• Rabbit 5000 Processor Easy Reference poster.
4MiniCore RCM5600W
1.3.3 Optional Add-Ons
Rabbit has a power supply and an Antenna Add-On Kit available for the RCM5600W.
• Separate power supply (Part No. 101-1273)
The universal AC adapter is available for customers who purchased the Standard
Development Kit. This universal AC adapter may be used if your RCM5600W does not
work when you power it through the USB cable, and you do not have your own +5 V
DC power supply.
• Antenna Add-On Kit (Part No. 101-1295)
X 2.4 GHz dipole antenna
X U.FL to RP-SMA connector cable
RCM5600W modules purchased individually or in production quantities do not come
with an antenna or a connector cable. The Antenna Add-On Kit provides a convenient
source of these items.
Visit our Web site at www.rabbit.com or contact your Rabbit sales representative or
authorized distributor for further information.
1.3.4 Software
The RCM5600W is programmed using version 10.50 or later of Dynamic C. A compatible
version is included on the Development Kit CD-ROM. This version of Dynamic C
includes the popular µC/OS-II real-time operating system, point-to-point protocol (PPP),
FAT file system, RabbitWeb, and other select libraries.
Rabbit also offers for purchase the Rabbit Embedded Security Pack featuring the Secure
Sockets Layer (SSL) and a specific Advanced Encryption Standard (AES) library. In addition to the Web-based technical support included at no extra charge, a one-year telephonebased technical support subscription is also available for purchase. Visit our Web site at
www.rabbit.com for further information and complete documentation, or contact your
Rabbit sales representative or authorized distributor
1.3.5 Online Documentation
The online documentation is installed along with Dynamic C, and an icon for the documentation menu can be placed on the workstation’s desktop. Double-click this icon to
reach the menu. If the icon is missing, use your browser to find and load
default.htm in
the docs folder, found in the Dynamic C installation folder.
The latest versions of all documents are always available for free, unregistered download
from our Web sites as well.
User’s Manual5
1.4 Certifications
The systems integrator and the end-user are ultimately responsible for the channel range
and power limits complying with the regulator y requirements of the co untry where the end
device will be used. Dynamic C function calls and sample programs illustrate how this is
achieved by selecting the country or region, which sets the channel range and power limits
automatically. See Section 6.2.4.1 for additional information and sample programs demonstrating how to configure an end device to meet the regulatory channel range and power
limit requirements.
Only RCM5600W modules bearing the FCC certification are certified for use in Wi-Fi
enabled end devices, and any applications must have been compiled using Dynamic C
v. 10.50 or later. The certification is valid only for RCM5600W modules equipped with
the dipole antenna that is included with the modules, or a detachable antenna with a 60 cm
coaxial cable (Digi International part number 29000105). Follow the antenna grounding
recommendations provided in Section 4.3.1. Changes or modifications to this equipment
not expressly approved by Digi International may void the user's authority to operate this
equipment.
In the event that these conditions cannot be met, then the FCC certification is no longer
considered valid and the FCC ID can not be used on the final product. In these circumstances, the systems integrator or end-user will be responsible for re-evaluating the end
device (including the transmitter) and obtaining a separate FCC certification.
NOTE: Any regulatory certification is voided if the RF shield on the RCM5600W
module is removed.
1.4.1 FCC Part 15 Class B
The RCM5600W MiniCore module has been tested and found to comply with the limits
for Class B digital devices pursuant to Part 15 Subpart B, of the FCC Rules. These limits
are designed to provide reasonable protection against harmful interference in a residential
environment. This equipment generates, uses, and can radiate radio frequency energy, and
if not installed and used in accordance with the instruction manual, may cause harmful
interference to radio communications. However, there is no guarantee that interference
will not occur in a particular installation. If this equipment does cause harmful interference to radio or television reception, which can be determined by turning the equipment
off and on, the user is encouraged to try and correct the interference by one or more of the
following measures:
• Reorient or relocate the receiving antenna.
• Increase the separation between the equipment and the receiver.
• Connect the equipment into an outlet on a circuit different from that to which the
receiver is connected.
• Consult the dealer or an experienced radio/TV technician for help.
6MiniCore RCM5600W
Labeling Requirements (FCC 15.19)
FCC ID: MCQ-MCWIFI
This device complies with Part 15 of FCC rules. Operation is
subject to the following two conditions:
(1) this device may not cause harmful interference, and
(2) this device must accept any interference received, including
interference that may cause undesired operation.
If the FCC identification number is not visible when the module is i nstalled inside another
device, then the outside of the device into which the module is installed must also display
a label referring to the enclosed module or the device must be capable of displaying the
FCC identification number electronically. This exterior label can use wording such as the
following: “Contains Transmitter Module FCC ID: MCQ-MCWIFI” or “Contains FCC
ID: MCQ-MCWIFI.” Any similar wording that expresses the same meaning may be used.
The following caption must be included with documentation for any device incorporating
the RCM5600W MiniCore module.
Caution — Exposure to Radio-Frequency Radiation.
To comply with FCC RF exposure compliance requirements, for mobile
configurations, a separation distance of at least 20 cm must be maintained
between the antenna of this device and all persons.
This device must not be co-located or operating in conjunction with any
other antenna or transmitter.
1.4.2 Industry Canada Labeling
IC: 1846A-MCWIFI RCM5600W
DIGI INTL
This Class B digital apparatus complies with Canadian standard
ICES-003.
Cet appareil numérique de la classe B est conforme à la norme
NMB-003 du Canada.
User’s Manual7
1.4.3 Europe
The marking shall include as a minimum:
• the name of the manufacturer or his trademark;
• the type designation;
• equipment classification, (see below).
Receiver
Class
1
2
3
Highly reliable SRD communication media, e.g., serving human life
inherent systems (may result in a physical risk to a person).
Medium reliable SRD communication media, e.g., causing
inconvenience to persons that cannot be overcome by other means.
Standard reliable SRD communication media,e.g., inconvenience to
persons that can simply be overcome by other means.
Risk Assessment of Receiver Performance
NOTE: Manufacturers are recommended to declare the classification of their devices in
accordance with Table 2 and EN 300 440-2 [5] clause 4.2, as relevant. In particular,
where an SRD that may have inherent safe ty of human life implications, manufacturers
and users should pay particular attention to the potential for interference from other
systems operating in the same or adjacent bands.
Regulatory Mark ing
The equipment shall be marked, where applicable, in accordance with CEPT/ERC Recommendation 70-03 or Directive 1999/5/EC, whichever is applicable. Where this is not applicable, the equipment shall be marked in accordance with the National Regulatory
requirements.
8MiniCore RCM5600W
2. GETTING S TARTED
This chapter describes the RC M560 0W hardw are i n m ore detai l, a nd
explains how to set up and use the accompanying Interface Board.
NOTE: This chapter (and this manual) assume that you have the RCM5600W Develop-
ment Kit. If you purchased an RCM5600W module by it self , you will hav e to adapt the
information in this chapter and elsewhere to your test and development setup.
2.1 Install Dynamic C
To develop and de bu g pro gr am s for the RC M560 0W mod ul es (and for al l oth e r Rabb i t
hardware), you must install and use Dynamic C.
If you have not yet installed Dynamic C version 10.50 (or a later version), do so now by
inserting the Dynamic C CD from the Development Kit in your PC’s CD-ROM drive. If
autorun is enabled, the CD installation will begin automatically.
If autorun is disabled or the installation does not start, use the Windows Start | Run menu
or Windows Disk Explorer to launch setup.exe from the root folder of the CD-ROM.
The installation program will guide you through the installation process. Most steps of the
process are self-explanatory.
Once your installation is complete, you will have up to three new icons on your PC desktop. One icon is for Dynamic C, another opens the documentation menu, and the third is for
the Rabbit Field Utility, a tool used to download precompiled software to a target system.
If you have purchased any of the optional Dynamic C modules, install them after installing
Dynamic C. The modules may be installed in any order. You must install the modules in
the same folder where Dynamic C was installed.
User’s Manual9
2.2 Hardware Connections
There are four4 steps to connecting the Interface Board for use with Dynamic C and the
sample programs:
1. Insert standoffs/connectors on the Interface Board.
2. Install the RCM5600W module on the Interface Board.
3. Connect antenna.
4. Connect the USB cable between the Interface Board and the workstation PC.
CAUTION: Provide ESD protection such as smocks and grounding straps on your
footwear.while assembling the RCM5600W module, installing it on another
board, and while making or removing any connections.
Remember to use ESD protection re gardl ess of whet her you are working wit h the
RCM5600W module on the Interface Board or in your own OEM application.
2.2.1 Step 1 — Prepare the Interface Board for Development
Insert a short plastic standoff supplied from the Development Kit in one of the corner
holes from the bottom of the Interface Board, then secure it with a long plastic standoff
from above as shown in Figure 2. Repeat this step so that plastic standoffs/connectors are
in place at three positions and the antenna bracket is at the fourth position.
Figure 2. Insert Standoffs/Connectors
10MiniCore RCM5600W
2.2.2 Step 2 — Install Module on Interface Board
Position the RCM5600W module with the edge connectors facing the mini PCI Express
socket J1A at an angle as shown in Figure 3 below. Insert the edge connectors into the
mini PCI Express socket J1A, then press down on the opposite edge of the RCM5600W
module to snap it into place in holder J1B.
RCM5600W
RCM5600W
J1A
J1B
Interface
Board
Figure 3. Install the RCM5600W Module on the Interface Board
Should you need to remove the
RCM5600W module, use two
fingernails to hold back the spring
clip at J1B from the two
RCM5600W corners, lift up the
edge of the RCM5600W above
J1B, then pull the RCM5600W
away to remove the edge connectors from the mini PCI Express
socket.
J1B
J1A
J1B
CAUTION: Remove power before at tempti ng to i nsert or re move the RCM5600W
in the mini PCI Express socket.
User’s Manual11
2.2.3 Step 3 — Connect Antenna
Install the antenna U.FL to RP-SMA connector cable in the bracket using two lockwashers
and the nut as shown in the insert in Figure 4. Connect the wire to connector P1 on the
RCM5600W, then attach the antenna to the antenna RP-SMA connector.
RESET
Connect
wire to P1
J5
6
4
8
2
JP1
Power LED
7
5
3
1
JP2
Figure 4. Connect Antenna and USB Cable
Alternate Antenna Connector Cable Installation
If you prefer, you may solder the
RP-SMA antenna connector directly
to the Interface Board at P1 as shown
in the diagram at right. Before doing
so, make sure that you use a long
plastic standoff instead of the antenna bracket. Then connect the wire
to connector P1 on the RCM5600W ,
and attach the antenna to the ant enna
RP-SMA connector.
CAUTION: Do not remove the RF shield
since any attempt to remove the shield
will damage the RF circuits underneath it.
Any regulatory certification is voided
if the RF shield on the RCM5600W
module is removed.
nut
lockwashers
P1
To
PC USB port
2.2.4 Step 4 — Connect USB Cable
The USB cable connects the RCM5600W to the PC running Dynamic C to download programs and to monitor the RCM5600W module during debugging. It also supplies power to
the Interface Board and the RCM5600W via the USB interface.
Connect the USB cable between USB connector J5 on the Interface Board and your PC as
shown in Figure 4. Note that the USB cable connectors are different at either end, so there
is only one way to connect them between the PC and the Interface Board.
12MiniCore RCM5600W
Your PC should recognize the new USB hardware, and the LEDs next to the USB connector on the Interface Board will flash — if you get an error message, you will have to install
USB driver s. Drivers for Windows XP are available in the Dynamic C
USB Programming Cable\WinXP_2K
folder — double-click DPInst.exe to install
Drivers\Rabbit
the USB drivers. Drivers for other operating systems are available online at
www.ftdichip.com/Drivers/VCP.htm.
The green power LED on the Interface Board should light up when you connect the USB
cable. The RCM5600W and the Interface Board are now ready to be used.
NOTE: A RESET button is provided on the Interface Board above the Ethernet jack to
allow a hardware reset without disconnecting power.
NOTE: Pins 1–2 on header JP1 on the Interface Board must be jumpered to download
and debug application s and sample programs wi th Dynamic C r unning. Pin s 1–2 shoul d
be left unjumpered to run an program already loaded in flash memory.
CAUTION: Do not jumper pins 1–3 on header JP1 on the Interface Board.
Alternate Power Supply Connections — Deluxe Development Kit
The deluxe Development Kit contains a separate AC adapter that may be used to supply
power to the Interface Board and the RCM5600W when the USB cable is not connected or
when more power is needed than the USB cable is able to supply. The AC adapter may
also be used to supply power when the USB cable is connected, in which case the power
supply through the USB cable will be disconnected automatically.
Remove slot cover,
1
insert tab into slot
Assemble
AC Adapter
Snap plug into place
RESET
2
AC Adapter
J6
+
Figure 5. Alternate Power Supply Connections—Deluxe Development Kit
User’s Manual13
First, prepare the AC adapter for the country where it will be used by selecting the plug.
The deluxe Development Kit presently includes Canada/Japan/U.S., Australia/N.Z., U.K.,
and European style plugs. Snap in the top of the plug assembly into the slot at the top of
the AC adapter as shown in Figure 5, then press down on the spring-loaded clip below the
plug assembly to allow the plug assembly to click into plac e. Release the c lip to secure the
plug assembly in the AC adapter.
Connect the AC adapter to DC input jack J6 on the Interface Board as shown in Figure 5.
Plug in the AC adapter. The green power LED on the Interface Board should light up. The
RCM5600W and the Interface Board are now ready to be used.
Note that the center pin of J6 is positive.
2.3 Run a Sample Program
If you already have Dynamic C installed, you are now ready to test your programming
connections by running a sample program. Start Dynamic C by double-clicking on the
Dynamic C icon on your desktop or in your
in the Dynamic C
Converter
is selected to support the USB cable. Choose Store Program in RAM on the
Options > Project Options menu and verify that Use USB to Serial
“Compiler” tab for faster compiling when running sample programs. Click
You may have to select the COM port assigned to the USB USB cable on your PC. In
Dynamic C, select
munications” tab, then click
Options > Project Options, then select this COM port on the “Com-
OK. You may type the COM port number followed by Enter
on your computer keyboard if the COM port number is outside the range on the dropdown
menu.
Start menu. Select the “Communications” tab
OK.
Now find the WIFISCAN.C sample program in the Dynamic C Samples\WiFi folder,
open it with the File menu, then compile and run the sample program by pressing F9.
The Dynamic C STDIO window will display Starting scan...., and will display a list
of access points/ad-hoc hosts similar to the one shown here.
The following fields are shown in the Dynamic C
STDIO window.
• Channel—the channel the access point is on (1–11).
• Signal—the signal strength of the access point.
• MAC—the hardware (MAC) address of access point.
• Access Point SSID—the SSID the access point is using.
14MiniCore RCM5600W
2.3.1 Troubleshooting
It may be possible that your PC or laptop is unable to deliver enough current through the
USB connection if you are not using a separate power supply. The RCM5600W will not
operate in this case, and the solution is to use a separate 5 V power supply as described in
the Alternate Power Supply Connections section. Contact Technical Support (see
Section 2.4.1) or visit our Web site if you would like to get the universal AC adapter from
the Deluxe Development Kit.
If you receive the message
Could Not Open Serial Port, check that the COM port
assigned to the USB cable was identified and set up in Dynamic C as described above.
This same error occurs when Windows has already allocated the COM port to another
process.
If you receive the message No Rabbit Processor Detected, the USB cable may
be connected to the wrong COM port, or the connection may be faulty. First, check both
ends of the USB cable to ensure that it is firmly plugged into the PC and the USB connector in the Interface Board. Ensure that the module is firmly and correctly installed in its
connector on the Interface Board.
If Dynamic C appears to compile the BIOS successfully, but you then receive a communication error message when you compile and load a sample program, it is possible that your
PC cannot handle the higher program-loading baud rate. Try changing the maximum
download rate to a slower baud rate as follows.
• Locate the
Options > Project Opti ons menu. Select a slower Max download baud rate. Click OK
Serial Options dialog on the “Communications” tab in the Dynamic C
to save.
If a program compiles and loads, but then loses target communication before you can
begin debugging, it is possible that your PC cannot handle the default debugging baud
rate. Try lowering the debugging baud rate as follows.
• Locate the Serial Options dialog on the “Communications” tab in the Dynamic C
Options > Project Options menu. Choose a lower debug baud rate. Click OK to save.
Press <Ctrl-Y> to force Dyn a m i c C to recom p il e t h e BIOS. You should receive a BIOS
successfully compiled
User’s Manual15
message once this step is completed successfully.
2.4 Where Do I Go From Here?
If the sample program ran fine, you are now ready to go on to other sample programs and to
develop your own applications. The sour ce code for the sample programs
you to modify them for your own use. The RCM5600W User’s Manual also provi
complete hardware reference information for the RCM5600W, the Interface Board, the Prototyping Board, and the accessory boards in the Deluxe Development Kit.
For advanced development topics, refer to the Dynamic C User’s Manual, also in the
online documentation set.
2.4.1 Technical Support
NOTE: If you purchased your RCM5600W through a distributor or through a Rabbi t p art -
ner, cont act the distributor or partner firs t for technical support.
If there are any problems at this point:
is provided to allow
des
• Use the Dynamic C
Help menu to get further assistance with Dynamic C.
• Check the Rabbit Technical Bulletin Board and forums at www.rabbit.com/support/bb/
and at www.rabbit.com/forums/.
• Use the Technical Support e-mail form at www.rabbit.com/support/.
16MiniCore RCM5600W
3. RUNNING SAMPLE PROGRAMS
To develop and debug programs for the RCM5600W (and for all
other Rabbit hardware), you must install and use Dynamic C.
This chapter provides a tour of its m ajor feat ures w ith res pect to
the RCM5600W.
3.1 Introduction
To help familiarize you with the RCM5600W modules, Dynamic C includes several
sample programs. Loading, executing and studying these programs will give you a solid
hands-on overview of the RCM5600W’s capabilities, as well as a quick start with
Dynamic C as an application development tool.
NOTE: The sample programs assume t hat you hav e at least an elementary grasp of ANSI
C. If you do not, see the introduct ory page s of the Dynamic C User’s Manual for a sug-
gested reading list.
In order to run the sample programs discussed in this chapter and elsewhere in this manual,
1. Your RCM5600W must be installed on the Interface Board as described in Chapter 2,
“Getting Started.”
2. Dynamic C must be installed and running on your PC.
3. The USB cable must connect the Interface Board to your PC.
4. Power must be applied to the RCM5600W through the Interface Board.
Refer to Chapter 2, “Getting Started,” if you need further information on these steps.
To run a sample program, open it with the
and run it by selecting Run in the Run menu (or press F9). The RCM5600W must be in
Program Mode (see Figure 11) and must be connected to a PC using the USB cable.
Complete information on Dynamic C is provided in the Dynamic C User’s Manual.
File menu (if it is not still open), then compile
User’s Manual17
3.2 Sample Programs
Of the many sample programs included with Dynamic C, several are specific to the
RCM5600W. These programs will be found in the SAMPLES\RCM5600W folder. Sample
programs in the SAMPLES folder one level up are generic samples that can be run on any
Rabbit-based product.
Before you compile and run the following sample programs, make sure
that pins 1–2, 5–6, and 7–8 on
header JP1 of the Interface Board
are jumpered. The pins on header
JP2 must also be jumpered. Each
sample program has comments that
describe the purpose and function of
the program. Follow the instructions
at the beginning of the sample
program.
CAUTION: Do not jumper pins
1–3 on header JP1 on the Interface Board.
JP1
6
4
8
2
JP2
7
5
3
1
•
FLASHLED.C—demonstrates the use of costatements to flash LED DS1 on the Inter-
face Board. PD0 on the RCM5600W is used to drive the LED.
•
TOGGLESWITCH.C—monitors switch S1 and LED DS1 on the Interface Board. LED
DS1 on the Interface Board is turned on and off when you press switch S1. PD0 on the
RCM5600W is used to drive the LED, and PD1 detects the activity on switch S1.
18MiniCore RCM5600W
The Digital I/O accessory board may also be used to run the TOGGLESWITCH.C and the
SERIALTOSERIAL.C sample programs. This accessory board is included only with the
Deluxe Development Kit.
To install the Digital I/O accessory board, insert the strip of header pins included with the
accessory board into the socket at J12 on the bottom side of the Digital I/O accessory
board. Then line up the Digital I/O accessory board with the Interface Board standoffs/
connectors and install the Digital I/O accessory board pins into socket J2 on the Interface
Board. Secure the Digital I/O accessory board with the long plastic standoffs/connectors
from above as shown in Figure 6—note that one plastic standoff/connector needs to be
inserted “upside down” to secure the Digital I/O accessory board to the antenna bracket.
6
4
8
Install header connector strip
in bottom socket
7
5
3
2
4
6
8
JP5
JP7
2
JP8
1
1
3
5
7
Figure 6. Install Digital I/O Accessory Board
Pins 1–2, 3–4, 5–6, and 7–8 on headers JP5 and JP8 on the Digital I/O accessory board
must be jumpered. Pins 2–4 and 3–5 on header JP7 on the Digital I/O accessory board
must also be jumpered.
Uncomment the following line in the sample programs when you are using the Digital I/O
accessory board.
#define DIGITAL_IO_ACCESSORY
• TOGGLESWITCH.C—monitors switches S1, S2, S3, and S4 on the Digital I/O acces-
sory board and lights LEDs DS1–DS4 when the corresponding pushbutton switch is
pressed. LEDs DS1–DS2 on the Digital I/O accessory board are controlled by PA4–
PA7, and switches S1–S4 are controlled by PB4–PB7 respectively.
User’s Manual19
The SERIALTOSERIAL.C sample program is in the SAMPLES\RCM5600W\SERIAL
folder.
•
SERIALTOSERIAL.C—monitors switches S1, S2, S3, and S4 on the Digital I/O acces-
sory board and lights LEDs DS1–DS4 when the corresponding pushbutton switch is
pressed. LEDs DS1–DS2 on the Digital I/O accessory bo ard are controlled by PA4–P A 7,
and switches S1–S4 are controlled by PB4–PB7 respectively . The sample program sends
messages from Serial Port B to Serial Port C to indicate that a switch was pressed.
Messages received by Serial Port C are displayed in Dynamic C’s
STDIO window.
Before you compile and run this
sample program, you will need to
J2
connect J2 pin 19 (PC0/TxD) to J2
pin 22 (PC3/RxC) or the correspond-
P2
ing holes on P2.
If you are using the Serial Communi-
cation accessory board, you should connect pin 3 (TXD) on header J3 to pin 5 (RXC)
on header J4 instead.
20MiniCore RCM5600W
4. HARDWARE REFERENCE
Chapter 4 describes the hardware components and principal hardware
subsystems of the RCM5600W. Appendix A, “RCM5600W Specifications,” provides complete physical and electrical specifications.
Figure 7 shows the Rabbit-based subsystems designed into the RCM5600W.
Wi-Fi
Serial
Flash
Real-Time
Clock
RABBIT
5000
SRAM
RCM5600W
MiniCore Module
Figure 7. RCM5600W Subsystems
Main
Clock
®
+3.3 V
CMOS-level
signals
Customer-specific
applications
User’s Manual21
4.1 RCM5600W Digital Inputs and Outputs
Figure 8 shows the RCM5600W pinouts for the edge connector.
The edge connectors are designed to interface with a 52-pin mini PCI Express socket.
22MiniCore RCM5600W
Figure 9 shows the use of the Rabbit 5000 microprocessor ports in the RCM5600W modules.
PC0, PC2, PC4
PC1, PC3, PC5
PA0PA7
Port A
Port C
(Serial Ports B, C & D)
PB0PB7
Port B
R
ABBIT
®
PD0PD3
Port D
Port E
PE0PE3
PE5PE7
5000
PB1, PC6, STATUS
PC7, /RESET_IN,
SMODE0, SMODE1
Serial Ports E & F
Programming
Port
(Serial Port A)
Wi-Fi
RAM
Real-Time Clock
Watchdog
11 Timers
Slave Port
Clock Doubler
Backup Battery
Support
Figure 9. Use of Rabbit 5000 Ports
Misc. I/O
Memory & I/O
Interface
/RESET_IN
/RESET
/IORD
/IOWR
The ports on the Rabbit 5000 microprocessor used in the RCM5600W are configurable,
and so the factory defaults can be reconfigured. Table 2 lists the Rabbit 5000 factory
defaults and the alternate configurations.
The Rabbit 5000 address lines (A0–A19) and data lines (D0–D7) are routed internally to
the onboard SRAM. I/0 write (/IOWR) and I/0 read (/IORD) are available for interfacing
to external devices.
Parallel Port A can also be used as an external I/O data bus to isolate external I/O from the
main data bus. Parallel Port B pins PB2–PB7 can also be used as an external address bus.
When using the external I/O bus for any other reason, you must add the following line at
the beginning of your program.
#define PORTA_AUX_IO // required to enable external I/O bus
Selected pins on Parallel Ports D and E as specified in Table 2 may be used for input
capture, quadrature decoder, DMA, and pulse-width modulator purposes.
4.1.2 Other Inputs and Outputs
The status, /RESET_IN, and SMODE I/O are normally associated with the programming
port. Since the status pin is not used by the system once a program has been downloaded
and is running, the status pin can then be used as a general-purpose CMOS output. The
programming port is described in more detail in Section 4.2.2.
/RESET_IN is an external input used to reset the Rabbit 5000 microprocessor and the
RCM5600W memory. /RESET is an output from the reset circuitry that can be used to
reset other peripheral devices.
The two SMODE pins, SMODE0 and SMODE1, are tied together to +3.3 V via a pullup
resistor, and may be used as a special input when the RCM5600W is operating in the Run
Mode. The logic state of these two pins determines the startup procedure after a reset.
28MiniCore RCM5600W
4.2 Serial Communication
The RCM5600W board does not have any serial level converters directly on the board.
However, an Ethernet or other serial interface may be incorporated on the board the
RCM5600W is mounted on. For example, the Serial Communication accessory board in
the Deluxe Development Kit has an RS-232 transceiver, and the Interface Board has
Ethernet and USB connections.
4.2.1 Serial Ports
There are six serial ports designated as Serial Ports A, B, C, D, E, and F. All six serial
ports can operate in an asynchronous mode up to the baud rate of the system clock divided
by 8. An asynchronous port can handle 7 or 8 data bits. A 9th bit address scheme, where
an additional bit is sent to mark the first byte of a message, is also supported.
Serial Port A is normally used as a programming port, but may be used either as an asynchronous or as a clocked serial port once application development has been completed and
the RCM5600W is operating in the Run Mode.
Serial Port B, shared by the RCM5600W module’s serial flash and by the A/D converter in
the Wi-Fi circuit, is set up as a clocked serial port. Since this serial port is set up for synchronous serial communication, you will lose the peripheral functionality if you try to use
the serial port in the asynchronous mode.
NOTE: Since Serial Port B is shared, exe rcise care if you attempt to us e Serial Port B for
other serial communication. Your application will have to manage the sharing negotiations to avoid conflicts when reading or writi ng to the devices already using Serial Port B.
Any conflict with Serial Port B while the RCM5600W is powering up may prevent an
application from loading from the serial flash when the RCM5600W powers up or resets.
Do not drive or load the Serial Port B or SCLKB (PC4, PC5, and PB0) pins while the
RCM5600W is powering up.
Serial Ports C and D can also be operated in the clocked serial mode. In this mode, a clock
line synchronously clocks the data in or out. Either of the two communicating devices can
supply the clock.
Serial Ports E and F can also be configured as SDLC/HDLC serial ports. The IrDA protocol is also supported in SDLC format by these two ports. Serial Ports E and F must be configured before they can be used. The following macros show one way to do this.
#define SERE_TXPORT PEDR
#define SERE_RXPORT PEDR
#define SERF_TXPORT PFDR
#define SERF_RXPORT PFDR
User’s Manual29
Table 3 summarizes the possible parallel port pins for the serial ports and their clocks.
RCLKE/TCLKE and RCLKF/TCLKF must be
selected to be on the same parallel port as
RXE/TXE and RXF/TXF respectively.
TXEPE6, PC6
TXFPD2, PE2, PC2
4.2.2 Programming Port
The RCM5600W programming port is accessed via the USB connector (J5) on the Interface Board. The programming port uses the Rabbit 5000’s Serial Port A for communication. Dynamic C uses the programming port to download and debug programs.
The programming port is also used to cold-boot the Rabbit 5000 on the RCM5600W after
a reset.
30MiniCore RCM5600W
4.3 Wi-Fi
Figure 10 shows a functional block diagram for the Wi-Fi circuits.
U4
Serial
Flash
U10
Rx
Baseband
Tx
Baseband
Rx Path
U8
AL2236
XCVR
Tx Path
P1
U15
Antenna
Switch
SRAM
3-wire serial bus
Figure 10. RCM5600W Wi-Fi Block Diagram
The Wi-Fi transmission is controlled by the Rabbit 5000 chip, which contains the Wi-Fi
Media Access Control (MAC). The Rabbit 5000 implements the 802.11b/g baseband
MAC functionality, and controls the 802.11b/g integrated Airoha AL2236 transceiver.
Program code is stored in the serial flash and is loaded into an SRAM for execution when
power is applied to the RCM5600W modules. The data interface between the processor
MAC and the AL2236 transceiver consists of a D/A converter and an A/D converter . Bot h
converters convert “I” and “Q” data samples at a rate of 40 MHz.
The AL2236 is a single-chip transceiver with integrated power amplifier for the 2.4 GHz
Industrial, Scientific, and Medical (ISM) band. It is configured and controlled by the
Rabbit 5000 via a 3-wire serial data bus. The AL2236 contains the entire receiver, transmitter, VCO, PLL, and power amplifier necessary to implement an 802.11b/g radio.
The AL2236 can transmit and receive data at up to 11Mbits/s in the 802.11b mode and at
up to 54 Mbits/s in the 802.1 1g mode. It supports 802.11b/g channels 1–13 (2.401 GHz to
2.472 GHz). Channel 14 is not used. The data modulate the channel carrier in such a way
so as to produce a spread spectrum signal within the 22 MHz channel bandwidth of the
selected channel. The channel numbers and associated frequencies are listed below in
Table 4.
The Wi-Fi channels have a certain amount of overlap with each other. The further apart
two channel numbers are, the less the likelihood of interference. If you encounter interference with a neighboring WLAN, change to a different channel. For example, use channels
1, 6, and 11 to minimize any overlap.
* These channels are disabled for units delivered for sale in the United
States and Canada.
Many countries specify the channel range and power limits for Wi-Fi devices operated
within their borders, and these limits are set automatically in the RCM5600W in firmware
according to the country or region. For example, only channels 1–11 are authorized for use
in the United States or Canada, and so channels 12 and 13 are disabled. See Section 6.2.4.1
for additional information and sample programs demonstrating how to configure an end
device to meet the regulatory channel range and power limit requirements. Table 5 provides additional information on which channels are allowed in selected countries. Any
attempt to operate a device outside the allowed channel range or power limits will void
your regulatory approval to operate the device in that country.
32MiniCore RCM5600W
The following regions have macros and region numbers defined for convenience.
Table 5. Worldwide Wi-Fi Macros and Region Numbers
RegionMacro
Americas
Mexico
Canada
Europe, Middle East,
Africa, except France
France
Israel
China
Japan
Australia
* Channel 14 is not available for the RCM5600W.
IFPARAM_WIFI_REGION_AMERICAS
IFPARAM_WIFI_REGION__MEXICO_
INDOORS
IFPARAM_WIFI_REGION_MEXICO_
OUTDOORS
IFPARAM_WIFI_REGION_CANADA
IFPARAM_WIFI_REGION_EMEA
IFPARAM_WIFI_REGION_FRANCE
IFPARAM_WIFI_REGION_ISRAEL
IFPARAM_WIFI_REGION_CHINA
IFPARAM_WIFI_REGION_JAPAN
IFPARAM_WIFI_REGION_AUSTRALIA
Region
Number
01–11
11–11 (indoors)
29–11 (outdoors)
31–11
41–13
510–13
63–11
71–11
8
91–11
Channel Range
*
1–14
The same omnidirectional antenna is used to transmit and receive the 802.11b/g RF signal.
An antenna switch isolates the high-power RF Tx signal path from the RF Rx signal path.
The antenna switch at U15 works by alternately connecting the antennas to either the
AL2236 Tx output or to the AL2236 Rx input. In order to support this antenna-sharing
scheme, the RCM5600W module operates the radio in a half-duplex mode so that receive
and transmit operations never occur at the same time
The RF connector on the Interface Board is an RP-SMA connector with its outer casing
attached to the RCM5600W ground.
There are two LEDs clos e to the RF s hield, a green LED at D S1 (
LINK) to indicate associa-
tion with the Wi-Fi access point, and a yellow LED at DS2 (ACT) to indicate activity.
4.3.1 Antenna Grounding Requirements
When deploying the RCM5600W in a production environment, take care to ensure that the
antenna is properly grounded via the RP-SMA connector and the U.FL to RP-SMA connector cable. The RP-SMA connector must be firmly attached to a bracket or soldered to a
grounded location. If you are using a bracket, it must make firm contact with a ground
such as the plated, grounded mounting hole provided on the Interface Board.
User’s Manual33
4.4 Programming Modes
The USB cable is used to connect the programming port of the RCM5600W to a PC USB
port via the Interface Board.
Whenever the RCM5600W is reset, the operating mode is determined by the state of the
SMODE pins. The RCM5600W is automatically in Program Mode when the SMODE
pins, which are tied together, are pulled up to +3.3 V. This happens when the RCM5600W
is installed on the Interface Board, and pins 1–2 on header JP1 on the Interface Board are
jumpered. When the SMODE pins are pulled low by removing the jumpers from pins 1–2
on header JP1 on the Interface Board, the Rabbit 5000 will operate in the Run Mode once
the RCM5600W is reset. The USB cable may be used for a serial connection to the programming port when the RCM5600W is operating in the Run Mode.
RESET
6
4
8
2
JP1
7
5
3
1
RESET RCM5600W when changing mode:
Short out /RESET_IN to GND,
OR
Press RESET button (if using Interface Board), OR
Cycle power off/on
after removing or attaching jumper on pins 12.
Figure 11. Switching Between Program Mode and Run Mode
A program “runs” in either mode, but can only be downloaded and debugged when the
RCM5600W is in the Program Mode.
Refer to the
Rabbit 5000 Microprocessor User’s Manual for more information on the pro-
gramming port.
34MiniCore RCM5600W
4.4.1 Standalone Operation of the RCM5600W
The RCM5600W must be programmed via the Interface Board or via a similar arrangement on a customer-supplied board. Once the RCM5600W has been programmed successfully, reset the RCM5600W. The RCM5600W may be reset by cycling power off/on or by
pressing the RESET button on the Interface Board. The jumper across pins 1–2 on header
JP1 on the Interface Board must be removed in order for the RCM5600W to operate in the
Run Mode after it is reset. The RCM5600W module may now be removed from the Interface Board for end-use installation.
CAUTION: Power to the Interface Board or other boards should be disconnected when
removing or installing your RCM5600W module to protect against inadvertent shorts
across the pins or damage to the RCM5600W if the pins are not plugged in correctly.
Do not reapply power until you have verified that the RCM5600W module is plugged
in correctly.
User’s Manual35
4.5 Other Hardware
4.5.1 Clock Doubler
The RCM5600W takes adva ntag e of th e Rabbi t 500 0 mic rop ro cesso r’s internal clock do ubler. A built-in clock doubler allows half-frequency crystals to be used to reduce radiated
emissions. The 73.73 MHz frequency specified for the RCM5600W model is generated
using a 36.864 MHz crystal.
The clock doubler should not be disabled since Wi-Fi operations depend highly on CPU
resources.
4.5.2 Spectrum Spreader
The Rabbit 5000 features a spectrum spreader, which helps to mitigate EMI problems. The
spectrum spreader is on by default, but it may also be turned off or set to a stronger setting.
The means for doing so is through a simple configuration macro as shown below.
1. Select the “Defines” tab from the Dynamic C Options > Project Options menu.
2. Normal spreading is the default, and usually no entry is needed. If you need to specify
normal spreading, add the line
ENABLE_SPREADER=1
For strong spreading, add the line
ENABLE_SPREADER=2
To disable the spectrum spreader, add the line
ENABLE_SPREADER=0
NOTE: The strong spectrum-spreading setting is not recommended since it may limit
the maximum clock speed or the maximum baud rate. It is unlikely that the strong setting will be used in a real application.
3. Click OK to save the macro. The spectrum spreader will be set according to the macro
value whenever a program is compiled using this project file.
NOTE: Refer to the Rabbit 5000 Microprocessor User’s Manual for more infor mat ion
on the spectrum-spreading setting and the maximum clock speed.
36MiniCore RCM5600W
4.6 Memory
4.6.1 SRAM
RCM5600W boards have 1MB of SRAM installed at U10.
4.6.2 Flash M emory
RCM5600W boards have 1MB of serial flash memory installed at U4.
A “user block” area is defined to store persistent data. The function calls
Block()
processor Designer’s Handbook
and readUserBlock() are provided for this. Refer to the Rabbit 5000 Micro-
for additional information.
writeUser-
4.6.3 Encryption RAM Memory
The tamper detection feature of the Rabbit 5000 microprocessor can be used to detect any
attempt to enter the bootstrap mode. When such an attempt is detected, the VBAT RAM
memory in the Rabbit 5000 chip is erased.
User’s Manual37
38MiniCore RCM5600W
5. SOFTWARE REFERENCE
Dynamic C is an integrated development system for writing
embedded software. It runs on a Windows-based PC and is
designed for use with sing le-board computers and other devices
based on the Rabbit microprocessor. Chapter 5 describes the
libraries and function calls related to the RCM5600W.
5.1 More About Dynamic C
Dynamic C has been in use worldwide since 1989. It is specially designed for programming embedded systems, and features quick compile and interactive debugging. A complete reference guide to Dynamic C is contained in the Dynamic C User’s Manual.
Since the RCM5600W has a serial flash memory, all software development must be done
in the static SRAM. The flash memory and SRAM o ptions are selected with the
Program Op tions > Compiler
NOTE: An application should be compiled directly to the SRAM on the RCM5600W
module using the Store Program in RAM
faster upload times and to save wear on the flash, but should be recompiled to Store Program in Flash after the USB cable is disconnected. Your final code must always
be stored in flash memory for reliable operation.
menu.
compiler option while debugging for
Options >
Developing software with Dynamic C is simple. Users can write, compile, and test C and
assembly code without leaving the Dynamic C development environment. Debugging
occurs while the application runs on the target. Alternatively, users can compile a program
to an image file for later loading. Dynamic C runs on PCs under Windows NT and later—
®
see Rabbit’s Technical Note TN257, Running Dynamic C
additional information if you are using a Dynamic C under Windows Vista. Programs can
be downloaded at baud rates of up to 460,800 bps after the program compiles.
OEM User’s Manual39
With Windows Vista®, for
Dynamic C has a number of standard features.
• Full-feature source and/or assembly-level debugger, no in-circuit emulator required.
• Royalty-free TCP/IP stack with source code and most common protocols.
• Hundreds of functions in source-code libraries and sample programs:
X Exceptionally fast support for floating-point arithmetic and transcendental functions.
X RS-232 and RS-485 serial communication.
X Analog and digital I/O drivers.
2
X I
C, SPI, GPS, file system.
X LCD display and keypad drivers.
• Powerful language extensions for cooperative or preemptive multitasking
• Loader utility program to load binary images into Rabbit targets in the absence of
Dynamic C.
• Provision for customers to create their own source code libraries and augment on-line
help by creating “function description” block comments using a special format for
library functions.
• Standard debugging features:
X Breakpoints—Set breakpoints that can disable interrupts.
X Single-stepping—Step into or over functions at a source or machine code level, µC/OS-II aware.
X Code disassembly—The disassembly window displays addresses, opcodes, mnemonics, and
machine cycle times. Switch between debugging at machine-code level and source-code level by
simply opening or closing the disassembly window.
X Watch expressions—Watch expressions are compiled when defined, so complex expressions
including function calls may be placed into watch expressions. Watch expressions can be updated
with or without stopping program execution.
X Register window—All processor reg isters and f lags are disp layed. The con tents of gener al regist ers
may be modified in the window by the user.
X Stack window—shows the contents of the top of the stack.
X Hex memory dump—displays the contents of memory at any address.
X STDIO window—
detected for debugging purposes.
printf outputs to this window and keyboard input on the host PC can be
printf output may also be sent to a serial port or file.
40MiniCore RCM5600W
5.2 Dynamic C Function Calls
5.2.1 Digital I/O
The RCM5600W was designed to interface with other systems, and so there are no drivers
written specifically for the Rabbit 5000 I/O. The general Dynamic C read and write functions allow you to customize the parallel I/O to meet your specific needs. For example, use
WrPortI(PEDDR, &PEDDRShadow, 0x00);
to set all the Port E bits as inputs, or use
WrPortI(PEDDR, &PEDDRShadow, 0xFF);
to set all the Port E bits as outputs.
When using the external I/O bus on the Rabbit 5000 chip, add the line
#define PORTA_AUX_IO // required to enable external I/O bus
to the beginning of any programs using the auxiliary I/O bus.
The sample programs in the Dynamic C
SAMPLES/RCM5600W
folder provide further
examples.
5.2.2 Serial Co mmunication Drive rs
Library files included with Dynamic C provide a full range of serial communications support. The
PACKET.LIB
RS232.LIB
library provides packet-based serial functions where packets can be delimited
library provides a set of circular-buffer-based serial functions. The
by the 9th bit, by transmission gaps, or with user-defined special characters. Both libraries
provide blocking functions, which do not return until they are finished transmitting or
receiving, and nonblocking functions, which must be called repeatedly until they are finished, allowing other functions to be performed between calls. For more information, see
the Dynamic C Fu nction Referen ce Manual and Rabbit Semiconductor’ s Technical Note
TN213, Rabbit Serial Port Software, both included with the online documentation.
OEM User’s Manual41
5.2.3 Serial Flash Memory Use
The RCM5600W module has a serial flash memory that contains the user block and stores
the application program. Two function calls are provided to work with the serial boot
flash. These function calls are in the Dynamic C
BOOTDEV_SFLASH.LIB
library.
LIB\Rabbit4000\BIOSLIB\
sbfRead
int sbfRead(void *dest, unsigned long offset, unsigned nbytes);
DESCRIPTION
Reads up to 64K from anywhere on the serial boot flash. This function call supports
both the blocking mode for use w ith µC/OS-II and a mutex for pr eemptive multitasking, and the nonblocking mode for cooperative multitasking. See the description for
sbfWriteFlash()
serial flash driver.
for more inform ation on u sing a µC/OS-II a nd a mutex with the
PARAMETERS
destnear pointer to the destination buffer
offsetthe physical offset into the serial flash
nbytesthe number of bytes to read
RETURN VALUE
0 if successful.
The return values below apply on ly if
positive N to indicate that the SPI port is being used by device n
if more than
available, one of the following two runtime errors will occur:
(when using µC/OS-II) or
_SPI_MAXTIME
-ETIME
_SPI_USE_UCOS_MUTEX
milliseconds elapse while waiting for the SPI port to become
(if not using µC/OS-II).
is not
#defined
ERR_SPI_MUTEX_ERROR
:
42MiniCore RCM5600W
sbfWriteFlash
int sbfWriteFlash(unsigned long flashDst, void* Src,
unsigned len);
DESCRIPTION
Writes
Keep calling
itive return va lue indicat es that the s erial flas h SPI port is b eing used b y another devi ce.
If you are using µC/OS-II and
call
sbfWriteFlash()
elapse while waiting fo r the SPI port to bec ome available, on e of the following two runtime errors will occur:
(if not using µC/OS-II).
NOTE: This functi on call is not power-fail safe. The
call provides a safer way to store critical data using redundant copies.
PARAMETERS
flashDstthe physical address of the flash destination
Srcnear pointer to the source data
lenthe number of bytes to write
RETURN VALUE
0 if successful.
len
bytes (up to 64K) to physical address
sbfWriteFlash()
until it returns zero or a negative error code. A pos-
_SPI_USE_UCOS_MUTEX
just once. If more than
ERR_SPI_MUTEX_ERROR
flashDst
_SPI_MAXTIME
from
is
#defined
Src
.
milliseconds
(when using µC/OS-II) or
writeUserBlock()
, you may
-ETIME
function
-1 if an attempt was made to write to the user/ID block or program area.
The return values below apply on ly if
-EBUSY
positive
if more than
available, one of the following two runtime errors will occur:
(when using µC/OS-II) or
OEM User’s Manual43
to indicate a busy writing to the serial flash
N
to indicate that the SPI port is being used by device n
_SPI_MAXTIME
-ETIME
_SPI_USE_UCOS_MUTEX
milliseconds elapse while waiting for the SPI port to become
(if not using µC/OS-II).
is not
#defined
ERR_SPI_MUTEX_ERROR
:
5.2.4 User and ID Blocks
The sample program USERBLOCK_INFO.C in the Dynamic C SAMPLES\USERBLOCK
folder can be used to determine the version of the ID block, the size of the ID and user
blocks, whether or not the ID/user blocks are mirrored, the total amount of flash memory
used by the ID and user blocks, and the area of the user block available for your application.
The
USERBLOCK_CLEAR.C sample program shows you how to clear and write the con-
tents of the user block that you are using in your application (the calibration constants in
the reserved area and the ID block are protected).
NOTE: Since RCM5600W MiniCore modules have a serial boot flash that shares the
serial flash SPI lines with other devices, exercise care when accessing the user block.
Pay attention to the instructions associated with the user block function calls in the
Dynamic C
LIB\Rabbit4000\BIOSLIB\IDBLOCK.LIB
library.
5.2.5 Wi-Fi Drivers
Complete information on the Wi-Fi libraries and function calls is provided in Chapter 6.
Additional information on TCP/IP is provided in the Dynamic C TCP/IP User’s Manual.
44MiniCore RCM5600W
5.2.6 Interface Board Function Calls
The function calls described in this section are for use with the Interface Board features.
The source code is in the Dynamic C
LIB\Rabbit4000\RCM5xxx\RCM56xxW.LIB
library if you need to modify it for your own board design.
The sample programs in the Dynamic C
SAMPLES\RCM5600W
folder illustrate the use of
the function calls.
Other generic functions applicable to all devices based on Rabbit microprocessors are
described in the Dynamic C Function Reference Manual.
5.2.6.1 Board Initialization
brdInit
void brdInit(void);
DESCRIPTION
Call this function at the beginning of your program. This function initializes Parallel
Ports A through E for use with the Int erface Board. This function call is intended for
demonstration purposes only, and can be modified for your applications.
Summary of Initialization
1. I/O port pins are configured for Interface Board operation.
2. Unused configurable I/O are set as outputs.
4. LEDs are off.
5. The slave port is disabled.
Pins PB0, PB1, PC6, PC7, PD4, PD7, and PE4 are configured separately by the BIOS and associ-
ated libraries. Parallel port H is configured automatically as part of the 16-bit memory setup, and
cannot be used as a general purpose I/O port.
RETURN VALUE
None.
OEM User’s Manual45
5.3 Upgrading Dynamic C
Dynamic C patches that focus on bug fixes are available from time to time. C heck the Web
site www.rabbit.com/support/ for the latest patches, workarounds, and bug fixes.
5.3.1 Add-On Modules
Starting with Dynamic C version 10.40, Dynamic C includes the popular µC/OS-II realtime operating system, point-to-point protocol (PPP), FAT file system, RabbitWeb, and
other select libraries. Rabbit also offers for purchase the Rabbit Embedded Security Pack
featuring the Secure Sockets Layer (SSL) and a specific Advanced Encryption Standard
(AES) library.
In addition to the Web-based technical support included at no extra charge, a one-year
telephone-based technical support subscription is also available for purchase.
V isit o ur Web site at www.rabbit.com for further information and complete documentation.
46MiniCore RCM5600W
6. USINGTHE WI-FI FEATURES
6.1 Introduction to Wi-Fi
Wi-Fi, a popular name for 802.1 1b/g, refers to the underlying technology for wireless local
area networks (WLAN) based on the IEEE 802.11 suite of specifications conforming to
standards defined by IEE E. IEEE 802.1 1b desc ribes the med ia access and link lay er control
for a 2.4 GHz implementation, which can communicate at a top bit-rate of 11 Mbits/s. Other
standards describe a faster implementation (54 Mbits/s) in the 2.4 GHz band (802.11g).
The adoption of 802.11 has been fast because it's easy to use and the performance is comparable to wire-based LANs. Things look pretty much like a wireless LAN.
Wi-Fi (802.11b/g) is the most common and cost-effective implementation currently available. This is the implementation that is used with the RCM5600W MiniCore module. A
variety of Wi-Fi hardware exists, from wireless access points (WAPs), various Wi-Fi
access devices with PCI, PCMCIA, CompactFlash, USB and SD/MMC interfaces, and
Wi-Fi devices such as Web-based cameras and print servers.
802.11b/g can operate in one of two modes—in a managed-access mode (BSS), called an
infrastructure mode, or an unmanaged mode (IBSS), called the ad-hoc mode. The 802.11
standard describes the details of how devices access each other in either of these modes.
6.1.1 Infrastructure Mode
The infrastructure mode requires an access point to manage devices that want to communicate with each other. An access point is identified with a channel and service set identifier
(SSID) that it uses to communicate. Typically, an access point also acts as a gateway to a
wired network, either an Ethernet or WAN (DSL/cable modem). Most access points can
also act as a DHCP server, and provide IP, DNS, and gateway functions.
When a device wants to join an access point, it will typically scan each channel and look
for a desired SSID for the access point. An empty-string SSID (" ") will associate the
device with the first SSID that matches its capabilities.
Once the access point is discovered, the device will logically join the access point and
announce itself. Once joined, the device can transmit and receive data packets much like
an Ethernet-based MAC. Being in a joined state is akin to having link status in a
10/100Base-T network.
802.11b/g interface cards implement all of the 802.11b/g low-level configurations in firmware. In fact, the 802.11b/g default configuration is often sufficient for a device to join an
User’s Manual47
access point automatically, which it can do once enabled. Comma nds issued to t he chip se t
in the interface allow a host program to override the default configurations and execute
functions implemented on the interface cards, for example, scanning for hosts and access
points.
6.1.2 Ad-Hoc Mode
In the ad-hoc mode, each device can set a channel number and an SSID to communicate
with. If devices are operating on the same channel and SSID, they can talk with each
other, much like they would on a wired LAN such as an Ethernet. This works fine for a
few devices that are statically configured to talk to each other, and no access point is
needed.
6.1.3 Additional Information
802.11 Wireless Networking; published by O'Reilly Media, provides further information about
802.11b wireless networks.
48MiniCore RCM5600W
6.2 Running Wi-Fi Sample Programs
In order to run the sample programs discussed in this chapter and elsewhere in this manual,
1. Your module must be plugged in to the Interface Board as described in Chapter 2, “Getting Started.”
2. Dynamic C must be installed and running on your PC.
3. The USB cable must connect the USB connector on the Interface Board to your PC.
4. Power must be applied to the module through the Interface Board.
Refer to Chapter 2, “Getting Started,” if you need further information on these steps.
T o run a sample program, open it with the File menu, then compile and run it by pressing F9.
Each sample program has comments that describe the purpose and function of the pro-
gram. Follow the instructions at the beginning of the sample program.
Complete information on Dynamic C is provided in the Dynamic C User’s Manual.
User’s Manual49
6.2.1 Wi-Fi Setup
Figure 12 shows how your development setup might look once you’re ready to proceed.
USB Cable
to PC USB port
Infrastructure Mode (via Ethernet connection)
Ethernet
Ethernet
Hub
Infrastructure Mode (via wireless connection)
Ad-Hoc Mode
Figure 12. Wi-Fi Host Setup
50MiniCore RCM5600W
6.2.2 What Else You Will Need
Besides what is suppl ied with the RCM560 0W Development Ki ts, you will need a PC with
an available USB port to program the RCM5600W module. You will need either an access
point for an existing Wi-Fi network that you are allowed to access and have a PC or notebook connected to that network (infrastructure mode), or you will need at least a PDA or
PC with Wi-Fi to use the ad-hoc mode.
User’s Manual51
6.2.3 Configuration Information
6.2.3.1 Network/Wi-Fi Configuration
Any device placed on an Ethernet-based Internet Protocol (IP) network must have its own
IP address. IP addresses are 32-bit numbers that uniquely identify a device. Besides the IP
address, we also need a netmask, which is a 32-bit number that tells the TCP /IP stack wha t
part of the IP address identifies the local network the device lives on.
The sample programs configure the RCM5600W modules with a default
TCPCONFIG
macro from the LIB\Rabbit4000\TCPIP\TCP_CONFIG.LIB library. This macro
allows specific IP address, netmask, gateway, and Wi-Fi parameters to be set at compile
time. Change the network settings to configure your RCM5600W module with your own
Ethernet settings only if that is necessary to run the sample programs; you will likely need
to change some of the Wi-Fi settings.
• Network Parameters
These lines contain the IP address, netmask, nameserver, and gateway parameters.
There are similar macros defined for the various Wi-Fi settings as explained in Section 6.3.1.
The Wi-Fi configurations are contained within TCPCONFIG 1 (no DHCP) and TCPCON-
FIG 5
TCPCONFIG 1
(with DHCP, used primarily with infrastructure mode). You will need to #define
or #define TCPCONFIG 5 at the beginning of your program.
NOTE: TCPCONFIG 0 is not supported for Wi-Fi applications.
There are some other “standard” configurations for TCPCONFIG. Their values are docu-
mented in the LIB\Rabbit4000\TCPIP\TCP_CONFIG.LIB library. More information
is available in the Dynamic C TCP/IP User’s Manual.
52MiniCore RCM5600W
6.2.3.2 PC/Laptop/PDA Configuration
This section shows how to configure your PC or notebook to run the sample programs.
Here we’re mainly interested in the PC or noteb ook that will be com municating wirelessly,
which is not necessarily the PC that is being used to compile and run the sample program
on the RCM5600W module.
This section provides configuration
information for the three possible Wi-Fi
setups shown in Figure 12. Start by
going to the control panel (Start >
Settings > Control Panel
Network Connections. The screen
) and click on
shots shown here are from Windows
2000, and the interface is similar for
other versions of Windows.
Check with your administrator if you are
unable to change the settings as
described here since you may need
administrator privileges.
When you are using an access point with your setup in the infrastructure mode, you will also
have to set the IP address and netmask (e.g., 10.10.6.99 and 255.255.255.0) for the access
point. Check the documentation for the access point for information on how to do this.
Infrastructure Mode (via Ethernet connection)
1. Go to the Local Ar ea Connection to
select the network interface card used you
intend to use (e.g.,
Card Network Adapter
TCP/IP Xircom Credit
) and click on the
“Properties” button. Depending on which
version of Windows your PC is running,
you may have to select the “Local Area
Connection” first, and then click on the
“Properties” button to bring up the Ethernet interface dialog. Then “configure”
your interface card for an “Auto-Negotiation” or “10Base-T Half-Duplex” connection on the “Advanced” tab.
NOTE: Your network interface card will
likely have a different name.
User’s Manual53
2. Now select the IP Address tab, and check
Specify an IP Address
, or select TCP/IP
and click on “Properties” to fill in the following fields:
a network, you will disconnect the PC
from that network to run these sample
programs. Write down the existing settings before changing them so that you
can restore them easily when you are finished with the sample programs.
The IP address and netmask need to be set
regardless of whether you will be using the
ad-hoc mode or the infrastructure mode.
3. Click <OK> or <Close> to exit the various dialog boxes.
Infrastructure Mode (via wireless connection)
Set the IP address and netmask for your wireless-enabled PC or notebook as described in
Step 2 for Infrastructure Mode (via Ethernet connection) by clicking on Network
Connec t ions
Connection
, then on Local Area Connection. Now click on Wireless Network
to select the wireless network you will be connecting to. Once a sample
program is running, you will be able to select the network from a list of available network s.
You will have to set your wireless network name with the access point SSID macro for the
infrastructure mode as explained in Section 6.3, “Dynamic C Wi-Fi Configurations.”
Ad-Hoc Mode
Set the IP address and netmask for your wireless-enabled PC or notebook as described in
Step 2 for
Connec t ions
Connection
Infrastructure Mode (via Ethernet connection) by clicking on Network
, then on Local Area Connection. Now click on Wireless Network
to select the wireless network you will be connecting to. Once a sample
program is running, you will be able to select the netwo rk f rom a list of av ailab le net work s.
You will have set your wireless network name with the Wi-Fi channel macros for the adhoc mode as explained in Section 6.3, “Dynamic C Wi-Fi Configurations.”
54MiniCore RCM5600W
Once the PC or notebook is set up, we're ready to communicate. You can use Telnet or a
Web browser such as Internet Explorer, which come with most Windows installations, to
use the network interface, and you can use HyperTerminal to view the serial port when
these are called for in some of the later sample programs.
Now we’re ready to run the sample programs in the Dynamic C
Samples\TCPIP\WiFi
folder. The sample programs should run as is in most cases.
6.2.4 Wi-Fi Sample Programs
The sample programs in Section 6.2.4.1 show how to set up the country- or region-specific
attributes, but do not show the basic setup of a wireless network. The sample programs in
Section 6.2.4.2 show the setup and operation of a wireless network — the
WIFISCAN.C
sample program is ideal t o demonstrate that the RCM 5600W has been hooked up correctly
and that the Wi-Fi setup is correct so that an access point can be found.
6.2.4.1 Wi-Fi Operating Region Configuration
The country or region you select will automatically set the power and channel requirements to operate the RCM5600W module. The following three options are available.
1. Country or region is set at compile time. This option is ideal when the end device is
intended to be sold and used only in a single region. If the end device is to be deployed
across multiple regions, this method would require an application image to be created for
each region. This option is the only approved option for RCM5600W modules in Japan.
2. Country or region is set via the 802.11d feature of the access point. This option uses
beacons from an access point to configure the RCM5600W country or region automatically. The end user is responsible for enabling 802.11d on the access point and then
selecting the correct country to be broadcast in the beacon packets.
NOTE: This option sets the power limi t for RCM5600W to the maximum level per mitted
in the region or the capability of the RCM5600W, whichever is less. Since the beacons
are being sent continuousl y, the ifconfig IFS_WIFI_TX_POWER function cannot
be used with this option.
3. Country or region is set at run time. This is a convenient option when the end devices
will be deployed in multiple regions. A serial user interface would allow the RCM5600W
module to be configured via a Web page. Systems integrators would still have to make
sure the end devices operate within the regulatory requirements of the country or region
where the units are being deployed.
These options may be used alone or in any combination. The three sample programs i n the
Dynamic C Samples\WiFi\Regulatory folder illustrate the use of these three options.
• REGION_COMPILETIME.C—demonstrates how you can set up your RCM5600Wbased system at compile time to operate in a given country or region to meet power and
channel requirements.
The country or region you select will automatically set the power and channel requirements to operate the RCM5600W module. Rabbit recommends that you check the
regulations for the country where your system incorporating the RCM5600W will be
User’s Manual55
deployed for any other requirements. Any attempt to operate a device outside the
allowed channel range or power limits will void your regulatory approval to operate
the device in that country.
Before you compile and run this sample program, uncomment the
WIFI_REGION
line corresponding to the region where your system will be deployed.
#define IFC_
The Americas region will be used by default if one of these lines is not uncommented.
Now compile and run this sample program. The Dynamic C
STDIO window will dis-
play the region you selected.
The sample program also allows you to set up the TCP/IP configuration, and set the IP
address and SSID as shown in the sample code below.
• REGION_MULTI_DOMAIN.C—demonstrates how the multi-domain options from the
access point can be used to configure your RCM5600W-based system to meet regional
regulations. The sample program includes pings to indicate that the RCM5600W-based
system has successfully received country information from your access point.
The country or region you select will automatically set the power and channel requirements to operate the RCM5600W module. Rabbit recommends that you check the
regulations for the country where your system incorporating the RCM5600W will be
deployed for any other requirements.
Before you compile and run this sample program, verify that the access point has the
802.11d option enabled and is set for the correct region or country. Check the TCP/IP
configuration parameters, the IP address, and the SSID in the macros, which are reproduced below.
Now compile and run this sample program. The #define WIFI_REGION_VERBOSE
macro will display the channel and power limit settings. The Dynamic C STDIO win dow will then display a menu that allows you to complete the configuration of the user
interface.
• REGION_RUNTIME_PING.C—demonstrates how the region or country can be set at
run time to configure your RCM5600W-based system to meet regional regulations. The
sample program also shows how to save and retrieve the region setting from nonvolatile memory . Once the region/country is set, this sample program sends pings using the
limits you set.
The country or region you select will automatically set the power and channel requirements to operate the RCM5600W module. Digi International recommends that you
check the regulations for the country where your system incorporating the RCM5600W
will be deployed for any other requirements.
56MiniCore RCM5600W
Before you compile and run this sample program, check the TCP/IP configuration
parameters, the IP address, and the SSID in the macros, which are reproduced below.
Now compile and run this sample program. Uncommen t the #define WIFI_REGION_
VERBOSE
macro to display the channel and power limit settings. The Dynamic C STDIO
window will then display a menu that allows you to complete the configuration of the
user interface.
6.2.4.2 Wi-Fi Operation
• WIFIDHCPORTSTATIC.C—demonstrates the runtime se lect ion of a static IP configur ation or DHCP. The
SAMPLES\TCPIP\DHCP.C sample program provides further exam-
ples of using DHCP with your application.
Before you compile and run this sample program, check the TCP/IP configuration
parameters, the IP address, and the SSID in the macros, which are reproduced below.
Modify the values to match your network. You may also need to modify the values for
MY_GATEWAY if you are not pinging from the local subnet.
Now press F9 to compile and run the sample program. When prompted in the Dynamic C
STDIO window, type 's' for static configuration or 'd' for DHCP.
• WIFIMULTIPLEAPS.C—demonstrates changing access points using WEP keys. You
will need two access points to run this sample program. The access points should be
isolated or on separate networks.
The sample program associates the RabbitCore or MiniCore module with the first access
point (
AP_0 defined below) with WEP key KEY0 (defined below). After associating,
the sample program waits for a predefined time period, and then pings the Ethernet
address of the access point (AP_ADDRESS_0). The sample program then associates
with the second access point and pings its Ethernet address (AP_1, KEY1, AP_
ADDRESS_1
), and then switches back and forth between the two access points.
When changing access points, first bring the IF_WIFI0 interface down by calling
ifdown(IF_WIFI0). Next, change the SSID and key(s) using ifconfig() calls.
Finally , bring the IF_WIFI0 interface back up by calling ifup(IF_WIFI0). Note that
the sample program checks for status while waiting for the interface to come up or
down.
Before you compile and run this sample program, check the TCP/IP configuration
parameters, the IP address, and the SSID in the macros, which are reproduced below.
You do not need to configure the SSID of your network since that is done from the
access point names.
Now configure the access to the two access points.
// First Access Point
#define AP_0 "test1"
#define AP_0_LEN strlen(AP_0)
#define MY_ADDRESS_0 "10.10.6.250"
#define PING_ADDRESS_0 "10.10.6.1" // address on AP 0 to ping
#define KEY_0 "0123456789abcdef0123456789"
// Second Access Point
#define AP_1 "test2"
#define AP_1_LEN strlen(AP_1)
#define MY_ADDRESS_1 "10.10.0.99"
#define PING_ADDRESS_1 "10.10.0.50"// address on AP 1 to ping
#define KEY_1 "0123456789abcdef0123456789"
Modify the access point names and keys to match your access points and network.
• WIFIPINGYOU.C—sends out a series of pings to a RabbitCore or MiniCore module on
an ad-hoc Wi-Fi network.
This sample program uses some predefined macros. The first macro specifies the
default TCP/IP configuration from the Dynamic C LIB\Rabbit4000\TCPIP\TCP_
CONFIG.LIB
#define TCPCONFIG 1
library.
Use the next macro unchanged as long as you have only one RCM5600W MiniCore
module. Otherwise use this macro unchanged for the first RabbitCore or MiniCore
module.
#define NODE 1
Then change the macro to #define NODE 2 before you compile and run this sample
program on the second RabbitCore or MiniCore module.
The next macros assign an SSID name and a channel number to the Wi-Fi network.
As long as you have only one RabbitCore or MiniCore module, the Dynamic C STDIO
window will display the pings sent out by the module. You may set up a Wi-Fi enabled
laptop with the IP address in
IPADDR_2 to get the pings.
If you have two RabbitCore or MiniCore modules, they will ping each other, and the
Dynamic C STDIO window will display the pings.
58MiniCore RCM5600W
• WIFISCAN.C—initializes the RCM5600W and scans for other Wi-Fi devices that are
operating in either the ad-hoc mode or through access points in the infrastructure mode.
No network parameter settings are needed since the RCM5600W does not actually join
an 802.11 network. This program outputs the results of the scan to the Dynamic C
STDIO window.
• WIFISCANASSOCIATE.C— demostrates how to scan Wi-Fi channels for SSIDs using
ifconfig IFS_WIFI_SCAN. This takes a while to complete, so ifconfig() calls a
callback function when it is done. The callback function is specified using
IFS_WIFI_SCAN
.
ifconfig
Before you run this sample program, configure the Dynamic C TCP_CONFIG.LIB
library and your
1. Use macro definitions in the “Defines” tab in the Dynamic C Options > Project Options menu to modify any parameter settings.
If you are not using DHCP, set the IP parameters to values appropriate to your network.
Set the macro IFC_WIFI_SSID= to define a C-style string to set the SSID of your
access point as, for example,
IFC_WIFI_SSID = "My Access Point"
or use an empty string, "", to associate with the strongest BSS available.
Alternatively, you may create your own CUSTOM_CONFIG.LIB library modeled on the
Dynamic C TCP_CONFIG.LIB library. Then use a TCPCONFIG macro greater than or
equal to 100, which will invoke your CUSTOM_CONFIG.LIB library to be used.
Remember to add the CUSTOM_CONFIG.LIB library to LIB.DIR.
2. If you are using DHCP, change the definition of the TCPCONFIG macro to 5. The def aul t
value of 1 indicates Wi-Fi with a static IP address.
Now compile and run the sample program. Follow the menu options displayed in the
Dynamic C STDIO window.
Press s to scan available access points
Press a to scan access points and associate
Press m to print WIFI MAC status
Note that ifconfig IFS_WIFI_SCAN function calls do not return data directly since
the scan takes a fair amount of time. Instead, callback functions are used. The callback
function is passed to
ifconfig() as the only parameter to IFS_WIFI_SCAN.
The data passed to the callback function are ephemeral since another scan may occur.
Thus, the data need to be used (or copied) during the callback function.
While waiting for user input, it is important to keep the network alive by calling
tcp_tick(NULL) regularly.
6.2.5 RCM5600W Sample Programs
The following sample programs are in the Dynamic C SAMPLES\RCM5600W\TCPIP\
folder. The Interface Board must be set up as described in Section 3.2.
PINGLED.C—This program demonstrates ICMP by pinging a remote host. It will pro-
•
duce a long flash of LED DS1 on the Interface Board when a ping is sent, and a short
flash when a ping is received.
Before you compile and run this sample program, change PING_WHO and IFC_WIFI_
SSID
to the host and SSID you want to ping. You may modify PING_DELAY to change
the amount of time in milliseconds between the outgoing pings.
Uncomment the
VERBOSE define to see the incoming ping replies.
• PINGLED_WPA_PSK.C—This program demonstrates the use of WPA PSK (Wi-Fi
Protected Access with Pre-Shared Key). WPA is a more secure replacement for WEP.
The implementation in the sample program supports use of the TKIP (Temporal Key
Integrity Protocol) cypher suite.
The sample program uses macros to configure the access point for WPA PSK, specify
the TKIP cypher suite, assign the access point SSID, and set the passphrase.
#define WIFI_USE_WPA // Bring in WPA support
#define IFC_WIFI_ENCRYPTION IFPARAM_WIFI_ENCR_TKIP // Define cypher suite
#define IFC_WIFI_SSID "rabbitTest"
The next macro specifies a suitable pre-shared key to use instead of the passphrase. The
key may be entered either as 64 hexadecimal digits or as an ASCII string of up to 63
characters. Authentication should be set to “open system,” which basically means that
knowing the key is sufficient to allow access.
TIP: There is a good chance of typos since the key is long. First, enter the key in this
sample program macro, then copy and paste it to your access point. This ensures that
both the RCM5600W and the access point have the same key.
TIP: For an initia l test , i t may be e asier to use the 64 hex di git f orm o f the k ey rat her tha n
the ASCII passphrase. A passphrase requires considerable computation effort, which
delays the startup of the sample program by about 30 seconds.
Change PING_WHO and IFC_WIFI_SSID to the host and SSID you want to ping. You
may modify
PING_DELAY to change the amount of time in milliseconds between the
outgoing pings.
Uncomment the
60MiniCore RCM5600W
VERBOSE define to see the incoming ping replies.
Once you have compiled the sample program and it is running, LED DS1 will go on
with a brief toggle off when a ping is sent. LED DS1 will go off for a longer duration
when a ping is received. LED DS1 is controlled by PD0.
• PINGLED_WPA2_CCMP.C—This sample program demonstrates the use of WPA2 PSK
(Wi-Fi Protected Access with Pre-Shared Key).). WPA is a more secure replacement
for WEP. The implementation in the sample program uses the Advanced Encryption
Standard (AES) based algorithm, also known as the CCMP (Counter Mode with Cipher
Block Chaining Message Authentication Code Protocol) cypher suite.
Apart from the configuration of
WPA2_CCMP at the top of the sample program, the rest
of the code is identical to the case without WPA2 PSK. Indeed, most of the TCP/IP
sample programs should work with WPA2 CCMP simply by using the same configuration settings.
Configure your access point for WPA2 PSK before you run this sample program.
Specify the CCMP cypher suite, and enter a suitable pre-shared key. The key may be
entered either as 64 hexadecimal digits or as an ASCII string of up to 63 characters.
Authentication should be set to “open system,” which basically means that knowingt
the key is sufficient to allow access.
TIP: There is a good chance of typos since the key is long. First, enter the key in this
sample program macro, then copy and paste it to your access point. This ensures that
both the RCM5600W and the access point have the same key.
TIP: For an initia l test , i t may be e asier to use the 64 hex di git f orm o f the k ey rat her tha n
the ASCII passphrase. A passphrase requires considerable computation effort, which
delays the startup of the sample program by about 30 seconds.
Now change PING_WHO and IFC_WIFI_SSID to the host and SSID you want to ping.
You may modify PING_DELAY to change the amount of time in milliseconds between
the outgoing pings.
Uncomment the VERBOSE define to see the incoming ping replies.
Once you have compiled the sample program and it is running, LED DS1 will go on
with a brief toggle off when a ping is sent. LED DS1 will go off for a longer duration
when a ping is received. LED DS1 is controlled by PD0.
User’s Manual61
• PINGLED_STATS.C—This program is similar to PINGLED.C, but it also displays
receiver/transmitter statistics in the Dynamic C STDIO window.
Before you compile and run this sample program, change PING_WHO and IFC_WIFI_
SSID
to the host and SSID you want to ping. You may modify PING_DELAY to change
the amount of time in milliseconds between the outgoing pings.
Modify the value in the
MOVING_AVERAGE macro to change the moving average filter-
ing of the statistics. Also review the GATHER_INTERVAL and GRAPHICAL macros,
which affect the number of sa mples to gather and create a bar graph display instead of a
numeric display.
Uncomment the VERBOSE define to see the incoming ping replies.
Once you compile and run this sample program, LED DS1 on the Interface Board will
go on with a brief toggle off when a ping is sent, and the LED will go off for a longer
duration when a ping is received.
• SMTP.C—This program demonstrates using the SMTP library to send an e-mail when
the S1 switch on the Interface Board is pressed. LED DS1 on the Interface Board will
light up when e-mail is being sent. LED DS1 is controlled by PD0.
62MiniCore RCM5600W
The Digital I/O accessory board may also be used to run the BROWSELED.C, PINGLED.C,
and PINGLED_STATS.C sample programs. This accessory board is included only with the
Deluxe Development Kit.
To install the Digital I/O accessory board, insert the strip of header pins included with the
accessory board into the socket at J12 on the bottom side of the Digital I/O accessory
board. Then line up the Digital I/O accessory board with the Interface Board
standoffs/
connectors and install the Digital I/O accessory board pins into socket J2 on the
Interface Board. Secure the Digital I/O accessory board with the long plastic standoffs/connectors from above as shown in Figure 13—note that one plastic standoff/connector needs to be inserted “upside down” to secure the Digital I/O accessory board to the
antenna bracket.
6
4
8
Install header connector strip
in bottom socket
7
5
3
2
4
6
8
JP5
JP7
2
JP8
1
1
3
5
7
Figure 13. Install Digital I/O Accessory Board
Pins 1–2, 3–4, 5–6, and 7–8 on headers JP5 and JP8 on the Digital I/O accessory board
must be jumpered. Pins 2–4 and 3–5 on header JP7 on the Digital I/O accessory board
must also be jumpered.
User’s Manual63
• BROWSELED.C—This program demonstrates a basic controller running a Web page.
Four “device LEDs” are created along with four buttons to toggle them. Users can use
their Web browser to change the status of the lights. The DS1, DS2, DS3, and DS4
LEDs on the Digital I/O accessory board will match those on the Web page. As long as
you have not modified the TCPCONFIG 1 macro in the sample program, enter the following server address in your Web browser to bring up the Web page served by the
sample program. Remember to configure the access point to match the default settings
of the TCPCONFIG 1 macro.
http://10.10.6.100.
Otherwise use the TCP/ IP settings y ou entered i n the in the “Defines” tab in the Dynamic C
Options > Project Options menu
.
Once you compile and run this sample program, you can use the buttons in the Web
browser to toggle the LEDs on the Digital I/O accessory board on/off.
• PINGLED.C—This program demonstrates ICMP by pinging a remote host. It will flash
LED DS2 on the Digital I/O accessory board when a ping is sent and it will flash LED
DS3 when a ping is received.
Before you compile and run this sample program, change PING_WHO and IFC_WIFI_
SSID
to the host and SSID you want to ping. You may modify PING_DELAY to change
the amount of time in milliseconds between the outgoing pings.
Uncomment the VERBOSE define to see the incoming ping replies.
• PINGLED_STATS.C—This program is similar to PINGLED.C, but it also displays
receiver/transmitter statistics in the Dynamic C STDIO window.
Before you compile and run this sample program, change PING_WHO and IFC_WIFI_
SSID
to the host and SSID you want to ping. You may modify PING_DELAY to change
the amount of time in milliseconds between the outgoing pings.
Modify the value in the MOVING_AVERAGE macro to change the moving average filter-
ing of the statistics. Also review the GATHER_INTERVAL and GRAPHICAL macros,
which affect the number of sa mples to gather and create a bar graph display instead of a
numeric display.
Uncomment the
VERBOSE define to see the incoming ping replies.
Once you compile and run this sample program, LED DS2 on the Digital I/O accessory
board will flash when a ping is sent, and LED DS3 will flash when a ping is received.
64MiniCore RCM5600W
The Serial Communication accessory board needs to be installed to run the SERIAL_TO_
WIFI.C
sample program. This accessory board is included only with the Deluxe Develop-
ment Kit.
To install the Serial Communication accessory board, insert the strip of header pins
included with the accessory board into the socket at J12 on the bottom side of the Serial
Communication accessory
with the Interface Board or Digital I/O acces sory board stan dof fs/
board. Then li ne up t h e
Serial Communication
connectors and install the
accessory board
Serial Communication accessory board pins into socket J2 on the Interface Board or the
Digital I/O accessory board. Secure the Serial Communication accessory board with the
long plastic standoffs/connectors from above as shown in Figure 14—note that one plastic
standoff/connector needs to be inserted “upside down” to secure the Serial Communication accessory board above the antenna bracket.
6
4
2
JP5
1
2
JP7
8
Install header connector strip
in bottom socket
7
5
3
4
1
3
Figure 14. Install Serial Communication Accessory Board
Pins 1–2, 3–4, 5–6, and 7–8 on header JP5 on the Serial Communication accessory board
must be jumpered. Pins 1–2 and 3–4 on header JP7 on the Serial Communication accessory board must also be jumpered.
• SERIAL_TO_WIFI.C—This program demonstrates using TCP over Wi-Fi, which is
handled automatically by the libraries. This sample program uses the RabbitWeb HTTP
enhancements to configure a simple serial to Wi-Fi converter.
This sample program only supports listening TCP sockets, which means that serial to
Wi-Fi devices can only be started by another device initiating the network connection
to the Rabbit.
User’s Manual65
Each serial port can be associated with a specific TCP port. The Rabbit will listen on
each of these TCP ports for a connection, which will then be associated with a specific
serial port. Data will then be shuttled between the serial and Wi-Fi connections.
Before you compile and run this sample program, define the
IFC_WIFI_SSID in the sample program to match your network settings.
and
_PRIMARY_STATIC_IP
Now compile and run this program.
As long as you have not modified the TCPCONFIG 1 macro in the sample program,
enter the following server address in your Web browser to bring up the Web page
served by the sample program. Remember to configure the access point to match the
default settings of the TCPCONFIG 1 macro.
http://10.10.6.100.
Select the serial port settings in the Web browser. You may leave the TCP port and baud
rate settings at their defaults, then set 8 data bits, no parity , and 1 stop bit. Click
Submit
to save the changed settings.
Now start a Telnet seession to associate a serial port with a TCP port is with telnet:
Open a cmd window via
Run > cmd and type telnet 10.10.6.100 4567 at the prompt to
associate Serial Port C, for example, where 4567 was the TCP port assigned to Serial
Port C in the previous setup performed via the Web browser.
Next, open a serial utility such as Tera Term or Hyperterminal configured to match the
settings selected via the Web browser. Finally, use the 10-pin to DB9 serial cable
included with the Deluxe Devlopment Kit to connect the PC serial port selected in your
serial utility to header J4 (Serial Port C) or header J3 (Serial Port D), depending on the
TCP port selected for the Telnet session. As you type characters in the Telnet utility
window, you will be able to observe them in the serial utility window, and vice versa.
66MiniCore RCM5600W
6.3 Dynamic C Wi-Fi Configurations
Rabbit has implemented a packet driver for the RCM5600W that functions much like an
Ethernet driver for the Dynamic C implementation of the TCP/IP protocol stack. In addition to functioning like an Ethernet packet driver, this driver impl ements a f unct ion call t o
access the functions implemented on the 802.11b/g interface, and to mask channels that
are not available in the region where the RCM5600W will be used.
The Wi-Fi interface may be used either at compile time using macro statements or at run
time with the
NET.LIB
6.3.1 Configuring TCP/IP at Compile Time
Digi International has made it easy for you to set up the parameter configuration using
already-defined
TCP_CONFIG.LIB
#define TCPCONFIG 1
ifconfig() function call from the Dynamic C LIB\Rabbit4000\TCPIP\
library.
TCPCONFIG
macros from the Dynamic C LIB\Rabbit4000\TCPIP\
library at the beginning of your program as in the example below.
There are two
RCM5600W module. (
TCPCONFIG
TCPCONFIG 0 is not supported for Wi-Fi applications.)
TCPCONFIG 1
TCPCONFIG 5
macros specifically set up for Wi-Fi applications with the
No DHCP
DHCP enabled
These default IP address, netmask, nameserver, and gateway network parameters are set
up for the
The use of quotation marks in the examples described in this chapter is important since the
absence of quotation marks will be flagged with warning messages when encrypted libraries are used.
Wi-Fi Parameters
• Access Point SSID—
IFC_
the
WIFI_SSID macro to a string for the SSID of the access point in the infra-
IFC_WIFI_SSID
. This is the only mandatory parameter. Define
structure (BSS) mode, or the SSID of the ad-hoc network in the ad-hoc (IBSS) mode.
The default is shown below.
#define IFC_WIFI_SSID "rabbitTest"
• Mode—
IFPARAM_WIFI_INFRASTRUCT for the infrastructure mode, or IFPARAM_WIFI_ADHOC
IFC_WIFI_MODE
determines the mode:
for the ad-hoc mode.
The default is shown below.
#define IFC_WIFI_MODE IFPARAM_WIFI_INFRASTRUCT
User’s Manual67
• Your Own Channel—
IFC_WIFI_CHANNEL
determines the channel on which to operate.
The default is shown below.
#define IFC_WIFI_CHANNEL 0
The default 0 means that any valid channel may be used by the requested SSID. This
parameter is mandatory when creating an ad-hoc network. While it is optional for the
infrastructure mode, it is usually best left at the default
0.
Note that there are restrictions on which channels may be used in certain countries.
These are provided in Table 5 for some countries.
• Region/Country—
IFC_WIFI_REGION
sets the channel range and maximum power
limit to match the region selected. Table 5 lists the regions that are supported and their
corresponding macros.
The region selected must match the region where the RCM5600W MiniCore module
will be used.
The default is shown below.
#define
• Disable/enable encryption—
IFC_
WIFI_REGION IFPARAM_WIFI_REGION_AMERICAS
IFC_WIFI_ENCRYPTION
indicates whether or not encryp-
tion is enabled.
The default (encryption disabled) is shown below.
• IFPARAM_WIFI_ENCR_ANY — any type of encryption is used.
• IFPARAM_WIFI_ENCR_WEP — use WEP encryption. You will need to define at least
one WEP key (see below).
• IFPARAM_WIFI_ENCR_TKIP — use TKIP or WPA encryption. You will need to
define a passphrase or a key for TKIP encryption, as well as define the WIFI_USE_WPA
macro (see below).
• IFPARAM_WIFI_ENCR_CCMP — use CCMP or WPA2 encryption. You will need to
define at least one WEP key (see below).
• There are four encryption keys ( 0, 1, 2, 3) associated with the IFC_WIFI_WEP_KEYNUM
macro (default 0). One or more of the following additional macros must be defined as
well. The default is for the keys to remain undefined.
IFC_WIFI_WEP_KEY0_BIN
IFC_WIFI_WEP_KEY1_BIN
IFC_WIFI_WEP_KEY2_BIN
IFC_WIFI_WEP_KEY3_BIN
68MiniCore RCM5600W
IFC_WIFI_WEP_KEY0_HEXSTR
IFC_WIFI_WEP_KEY1_HEXSTR
IFC_WIFI_WEP_KEY2_HEXSTR
IFC_WIFI_WEP_KEY3_HEXSTR
These macros specify the WEP keys to use for WEP encryption. These keys can be
either 40-bit or 104-bit (i.e., 5 bytes or 13 bytes). They must be defined as a commaseparated list of byte values.
Note that you do not necessarily need to define all four WEP keys. You may typically
just define one key, but make sure it matches the key used on all other devices, and set
IFC_WIFI_WEP_KEYNUM to point to the correct key.
If both IFC_WIFI_WEP_KEY#_BIN and IFC_WIFI_WEP_KEY#_HEXSTR are defined
for a particular key, the hex version will be used.
• Use WPA encryption.
The following macro must also be used to compile WPA functionality into the Wi-Fi
driver. This is necessary to enable TKIP encryption.
#define WIFI_USE_WPA
• Set WP A passphrase—IFC_WIFI_WPA_PSK_PASSPHRASE is a str ing that matches the
passphrase on your access point. It may also point to a variable.
Define an ASCII passphrase here, from 1 to 63 characters long. An example is shown
below.
#define IFC_WIFI_WPA_PSK_PASSPHRASE "now is the time"
If possible, you should use IFC_WIFI_WPA_PSK_HEXSTR instead of IFC_WIFI_
WPA_PSK_PASSPHRASE
to set the key.
• Set WPA hexadecimal key—IFC_WIFI_WPA_PSK_HEXSTR is a string of hexadecimal
digits that matches the 256-bit (32-byte) hexadecimal key used by your access point.
Specify a 64 hexadecimal digit (256 bits) key here. This key will be used and will override any passphrase set with the IFC_WIFI_WPA_PSK_PASSPHRASE macro. The
example hex key shown below
is valid for the SSID "rabbitTest" and the passphrase "now is the time".
Using a passphrase is rather slow. It takes a Rabbit 5000 more than 20 seconds to gen-
erate the actual 256-bit key from the passphrase. If you use a passphrase and #define
WIFI_VERBOSE_PASSPHRASE
, the Wi-Fi library will helpfully print out the hex key
corresponding to that passphrase and SSID.
• Authentication algorithm—IFC_WIFI_AUTHENTICATION can be used to specify the
authentication modes used.
The default shown below allows enables both open-system authentication and sharedkey authentication.
#define IFPARAM_WIFI_AUTH_ANY
User’s Manual69
The following authentication options are available.
• IFPARAM_WIFI_AUTH_OPEN — only use open authentication.
• IFPARAM_WIFI_AUTH_SHAREDKEY — only use shared-key authentication (useful
for WEP only).
• IFPARAM_WIFI_WPA_PSK — use WPA preshared-key authentication (useful for
TKIP and CCMP only).
• Fragmentation threshold—IFC_WIFI_FRAG_THRESHOLD sets the fragmentation
threshold. Frames (or packets) that are larger than this threshold are split into multiple
fragments. This can be useful on busy or noisy networks. The value can be between
256 and 2346.
The default, 0, means no fragmentation.
#define IFC_WIFI_FRAG_THRESHOLD 0
• RTS threshold—IFC_WIFI_RTS_THRESHOLD sets the RTS threshold, the frame size
at which the RTS/CTS mechanism is used. This is sometimes useful on busy or noisy
networks. Its range is
1 to 2347.
The default,
#define IFC_WIFI_RTS_THRESHOLD 2347
2347, means no RTS/CTS.
Examples are available within Dynamic C. Select “Function Lookup” from the Help
menu, or press <ctrl-H>. Type “TCPCONFIG” in the Function Search field, and hit
<Enter>. Scroll down to the section on “Wi-Fi Configuration.” The Dynamic C TCP/IP
User’s Manual.(Volume 1) provides additional information about these macros and Wi-Fi.
It is also possible to redefine any of the above parameters dynamically using the ifcon-
fig()
ifconfig() function call, and may be used to change the above default macros or
function call. Macros for alternative Wi-Fi configurations are provided with the
configurations.
70MiniCore RCM5600W
6.3.2 Configuring TCP/IP at Run Time
There is one basic function call used to configure Wi-Fi and other network settings —
ifconfig(). See the Dynamic C TCP/IP User’s Manual, Volume 1 for more informa-
tion about this function call.
6.3.3 Other Key Function Calls
Remember to call
sock_init() after all the Wi-Fi parameters have been defined. The
Wi-Fi interface will be up automatically as long as you configured Dynamic C at compile
time with one of the
TCPCONFIG macros. Otherwise the Wi-Fi interface is neither up nor
down, and must be brought up explicitly by calling either ifup(IF_WIFI0) or
ifconfig(IF_WIFI0,…). You must bring the interface down when you configure
Dynamic C at run time before modifying any parameters that require the interface to be
down (see Section 6.3.2) by calling
Finally, no radio transmission occurs until you call
Instead of executing the above sequence based on
init_or_exit(1)
as a debugging tool to transmit packets (ARP, DHCP, association,
ifdown(IF_WIFI0). Then bring the interface back up.
tcp_tick(NULL).
sock_init(), you could use sock_
and authentication) while bringing up the interface and to get the IP address.
User’s Manual71
6.4 Where Do I Go From Here?
NOTE: If you purchased your RCM5600W through a distributor or through a Rabbi t p art -
ner, cont act the distributor or partner firs t for technical support.
If there are any problems at this point:
• Use the Dynamic C
Help menu to get further assistance with Dynamic C.
• Check the Rabbit Technical Bulletin Board and forums at www.rabbit.com/support/bb/
and at www.rabbit,com/forums/.
• Use the Technical Support e-mail form at www.rabbit.com/support/.
If the sample programs ran fine, you are now ready to go on.
An Introduction to TCP/IP and the Dynamic C TCP/IP User’s Manual.provide
background and reference information on TCP/IP, and are available on the CD and on our
Web site.
72MiniCore RCM5600W
APPENDIX A. RCM5600W
SPECIFICATIONS
Appendix A provides the specifications for the RCM5600W.
User’s Manual73
A.1 Electrical and Mechanical Characteristics
0
Figure A-1 shows the mechanical dimensions for the RCM5600W.
(30)
1.20
0.114
(2.9)
0.958
0.114
(2.9)
0.114
(2.9)
(24.3)
0.125
(3.2)
1.762
(44.8)
2.00
(51)
2.00
(51)
dia
× 2
(8.3)
0.326
0.157
(4.0)
0.642
(16.3)
0.130
(3.3)
0.326
0.085
(2.2)
0.050
(1.3)
0.324
(8.2)
0.085
(2.2)
(8.3)
0.039
0.4
(10)
(1.0)
0.40
(10)
1.20
(30)
(1.0)
0.039
Figure A-1. RCM5600W Dimensions
74MiniCore RCM5600W
It is recommended that you allow for an “exclusion zone” of 0.08" (2 mm) around the
RCM5600W top and bottom and 0.04" (1 mm) around the three non-connector edges
when the RCM5600W is incorporated into an assembly that includes other printed circuit
boards. This “exclusion zone” that you keep free of other components and boards will
allow for sufficient air flow, and will help to minimize any electrical or electromagnetic
interference between adjacent boards. Figure A-2 shows this “exclusion zone.”
(2)
0.08
(2)
0.08
(8.3)
0.326
2.00
(51)
0.04
(1)
(2)
0.08
(2)
0.08
(8.3)
0.326
0.04
(1)
1.20
(30)
0.04
(1)
Figure A-2. RCM5600W “Exclusion Zone”
Exclusion
Zone
User’s Manual75
T ableA-1 lists the electrical, mechanical, and environmental specifications for the
RCM5600W.
Table A-1. RCM5600W Specifications
ParameterRCM5600W
Microprocessor
EMI ReductionSpectrum spreader for reduced EMI (radiated emissions)
Serial Flash Memory
(program)
SRAM1MB
Backup Battery
General-Purpose I/O
Additional InputsReset in
Additional OutputsStatus, reset out
External I/O Bus
up to 35 parallel digital I/0 lines configurable with four layers of
alternate functions
6 high-speed, CMOS-compatible ports:
Connection for user-supplied backup battery
Can be configured for 8 data lines and
8 address lines (shared with parallel I/O lines),
®
Rabbit
5000 at 73.73 MHz
1MB
(to support RTC)
plus I/O read/write
• all 6 configurable as asynchronous (with IrDA), 4 as clocked serial
Serial Ports
(SPI), and 2 as SDLC/HDLC
• 1 clocked serial port shared with programming port
Serial RateMaximum asynchronous baud rate = CLK/8
Slave Interface
Real-Time ClockYes
Timers
W atchdog/SupervisorYes
Pulse-Wi dth Modulators
Input Capture
Quadrature Decoder
Slave port allows the RCM5600W to be used as an intelligent
peripheral device slaved to a master processor
Ten 8-bit timers (6 cascadable from the first),
one 10-bit timer with 2 match registers, and
one 16-bit timer with 4 outputs and 8 set /reset registers
4 channels synchronized PWM with 10-bit counter or
4 channels variable-phase or synchronized PWM with 16-bit
counter
2-channel input capture can be used to time input s ignals from vari ous
port pins
2-channel quadrature decoder accepts inputs
from external incremental encoder modules
76MiniCore RCM5600W
Table A-1. RCM5600W Specificati ons (continued)
ParameterRCM5600W
3.15 V DC (min.) – 3.45 V DC (max.)
Power
Operating T emperatu re–30°C to +55°C
Humidity5% to 95%, noncondensing
625 mA @ 3.3 V while transmitting/receiving
85 mA @ 3.3 V while not transmitting/receiving
Connectors
Board Size
Typical Average Antenna
Output Power
Compliance 802.11b/g, 2.4 GHz
Edge connectors for interface with
52-pin mini PCI Express socket
1.20" × 2.00" × 0.40"
(30 mm × 51 mm × 10 mm)
Wi-Fi
Region802.11b802.11g
Americas, Japan19 dBm
Other Regions18 dBm
15 dBm
User’s Manual77
A.1.1 mini PCI Express Connector Design Recommendations
The RCM5600W is mounted on the Interface Board via a mini PCI Express connector
and a corresponding locking latch connector. These are offered by manufacturers as a
matched set, although in some cases different manufacturer’s parts may be interchangeable. Table A-2 lists the recommended parts for the mini PCI Express connector and the locking
latch connector used for the Interface Board.
Table A-2. Interface Board Connect or-Related Parts
Connector PartManufacturer Part Number
mini PCI Express ConnectorPinrex 984-63-052202498-0090
Latch ConnectorFOXCONN AS0B226S68K-7F498-0091
Rabbit Store Part
Number
Other manufacturers such as Molex offer similar connectors and latches, but these can
have different mechanical structures and PCB footprints to what we use on the Interface
Board. Table A-3 lists a pair of matched Molex parts that might be used.
Table A-3. Molex Connector-Related Parts
Connector PartMolex Part Number
mini PCI Express Connector67910-0002
Latch Connector48099-4000
Follow the PCB design and layout recommendations and considerations provided by the
manufacturer for the connector and latch that you select.
78MiniCore RCM5600W
A.2 Rabbit 5000 Microprocessor Characteristics
The Rabbit 5000 Microprocessor User’s Manual, which is included with the online docu-
Designs, which is also included with the online documentation, contains suggestions for
interfacing I/O devices to the Rabbit 5000 microprocessors.
, provides complete specifications and timing diagrams for the Rabbit 5000
User’s Manual79
80MiniCore RCM5600W
APPENDIX B. INTERFACE BOARD
Appendix B describes the features and accessories of the Interface Board, and explains the use of the Interface Board to demonstrate the RCM5600W . The Interface Board has power-supply
connections and a USB interface to program the RCM5600W.
User’s Manual81
B.1 Introduction
The Interface Board included in the Development Kit makes it easy to connect an
RCM5600W module to a power supply and a PC workstation for development.
The Interface Board is shown below in Figure B-1, with its main features identified.
mini PCI Express
socket
RCM5600W
Snap-In holder
Program/Run Mode
Switch/LED
Jumper Settings
Stacking
User Interface
Connector
User
LED
Power
LED
User
Switch
Reset
Switch
Current-Limiting
Configuration
Jumper
mini USB
Programming/Power
Connector
USB LEDs
Power Input
Jack
+
Figure B-1. Interface Board
82MiniCore RCM5600W
B.1.1 Interface Bo ard Features
• Power Connection—Power is supplied to the Interface Board either from the PC via
the USB connection or through a power supply jack, J6. A chip at U4 disconnects the
USB power supply from the rest of the Interface Board when power is supplied through
jack J6.
Users providing their own power suppl y should ens ure that i t delivers +5 V DC at 10 W.
• Regulated Power Supply—The raw DC voltage is routed to a 3.3 V linear regulator.
The regulator provides stable power to the RCM5600W module and other boards connected to it.
Power LED—The power LED lights whenever power is connected to the Interface
•
Board.
•
Reset Switch—A momentary-contact, normally open switch is connected directly to the
RCM5600W’ s
/RESET_IN pin. Pressing the switch forces a hardware reset of the system.
• mini USB Connector—A USB cable is used to connect the RCM5600W via the Interface Board to your PC to enable you to program your RCM5600W module.
•
mini PCI Express socket—The Interface Board provides a 52-pin mini PCI Express
socket to enable you to install your RCM5600W module. There is a snap-in holder to
hold the opposite end of the RCM5600W module firmly in place.
• I/O Switch and LED—One momentary-contact, normally open switch is connected to
PD1 on the RCM5600W module and may be read as an input by sample applications.
One LED is connected to PD0 on the RCM5600W module, and may be driven as an
output indicator by sample applications.
User’s Manual83
B.2 Mechanical Dimensions and Layout
Figure B-2 shows the mechanical dimensions and layout for the Interface Board.
dia
0.125
(3.2)
× 4
0.175
0.628
(4.4)
0.181
(4.6)
(15.9)
0.130
(3.3)
0.304
(7.7)
0.317
(8.1)
0.360
(9.1)
0.230
(5.8)
(64)
2.50
0.15
(3.8)
3.45
(88)
3.75
(95)
0.15
(3.8)
(4.4)
0.175
Figure B-2. Interface Board Dimensions
Table B-1 lists the electrical, mechanical, and environmental specifications for the Interface Board.
Table B-1. Interface Board Specifications
ParameterSpecification
Board Size2.50" × 3.75" × 0.60" (64 mm × 95 mm × 15 mm)
Operating Temperature–40°C to +85°C
Humidity5% to 95%, noncondensing
Input Voltage +5 V DC
Output Voltage+3.3 V DC
Maximum Current Draw
(includi ng user-added circuits)
Other Connectors
nominal 750 mA max. for USB supply,
1.5 A for separate power supply
One 2 × 25 IDC header sockets, 0.1" pitch,
One 52-pin mini PCI Express socket to accept RCM5600W
One mini USB connector
One 2 mm power supply jack
Standoffs/Spacers4
84MiniCore RCM5600W
B.2.1 Headers
The Interface Board has a header socket at J2 for physical connection to other boards. J2 is
a 2 × 25 SMT header socket with a 0.1" pin spacing. Figure B-3 shows the layout of
another board to be plugged into the Interface Board — this footprint is identical for the
Interface Board and the two accessory boards. The values are relative to the mounting
hole.
0.275
(1.27)
0.110
(2.8)
J2
MiniCore Boards
Footprint
Figure B-3. Interface Board Footprint
User’s Manual85
B.3 Power Supply
The RCM5600W requires a regulated 3.15 V – 3.45 V DC power source to operate.
Depending on the amount of current required by the application, different regulators can
be used to supply this voltage.
The Interface Board has an onboard +3.3 V linear regulator. The Interface Board is protected against reverse polarity by a Shottky diode at D3 as shown in Figure B-4.
LINEAR POWER
J6
2
1
IN
3
POWER
J5
+RAW
D3
B240
CONTROLLER
D1
B240
D2
B240
REGULATOR
LD29150DT33R
1
U1
10 µF
2
+3.3 V
3
10 µF
VBUS
mini USB
CONNNECTOR
U4
POWER
SWITCH
Figure B-4. Interface Board Power Supply
Power may be supplied to the Interface Board either via the mini USB connector at J5 or
through the power supply jack J6. When a separate power supply is used, the chip at U4
disables power from the mini USB connector, which continues to supply power only to the
USB interface chip. Diodes at D1 and D2 prevent power from going back to the other
power supply that is not supplying power. A separate power supply is required whenever
the Interface Board is not connected to the PC.
A jumper on header JP2 controls the current limiting applied to the power drawn via the
mini USB connector — the current is nominally limited to 700 mA when a jumper is
installed (default), and is nominally limited to 500 mA when no jumper is installed.
86MiniCore RCM5600W
B.4 Using the Interface Board
The Interface Board is also a demonstration board. It can be used to demonstrate the functionality of the
The Interface Board comes with the basic components necessary to demonstrate the operation of the RCM5600W. One LEDs (DS1) is connected to PD0, and one switch (S1) is
connected to PD1 to demonstrate the interface to the Rabbit 5000 microprocessor. Reset
switch S2 is the hardware reset for the RCM5600W.
RCM5600W
right out of the box without any modifications to either board.
The Interface
veniently to header
Board provides the user with RCM5600W connection points b rought out con-
socket
J2. Other boards such as the Prototyping Board or the accessory
boards from the Deluxe Development Kit can be plugged into header socket J2.
for header socket J2 are shown in Figure B-5.
J2
GND
PE1
PE3
PE6
SMODE
PD1
PD3
/RESET
GND
PC1
PC3
PC5/RxB
PC7/RxA
PB1/SCLKA
PB3
PB5
PB7
GND
PA1
PA3
PA5
PA7
/IOWR
VBAT_EXT
GND
+3.3 V
PE0
PE2
PE5
PE7
PD0
PD2
/RESET_IN
+3.3 V
PC0
PC2
PC4/TxB
PC6/TxA
PB0/SCLKB
PB2
PB4
PB6
+3.3 V
PA0
PA2
PA4
PA6
/IORD
STATUS
+3.3 V
The pinouts
These pinouts are as seen on
Note:
the Top Side.
Figure B-5. Interface Board Pinout
User’s Manual87
B.4.1 Add Additional Boards
The Prototyping Board and the two accessory boards included with the Deluxe Development Kit may be installed on the Interface Board as shown in Figure B-6.
Install header connector strip
in bottom socket
Figure B-6. Install Additional Boards on Interface Board
1. Insert the header strip into header socket J2 on the Interface Board or the board already
installed above the Interface Board.
2. Line up the board being installed above the pins extending from the header socket and
the stand-offs/connectors.
3. Press down to install the board.
4. Insert additional plastic standoffs/connectors as shown to hold the board firmly in place
and to hold another board if desired.
When additional boards are installed, the board-to-board spacing is 0.7" (17.8 mm).
Multiple boards should be installed in this sequence from bottom to top.
• Interface Board with RCM5600W installed.
• Prototyping Board.
• Serial Communication accessory board.
• Digital I/O accessory board.
88MiniCore RCM5600W
B.5 Interface Board Jumper Configurations
Figure B-7 shows the header locations used to configure the various Interface Board
options via jumpers.
JP1
Figure B-7. Location of Configurable Jumpers on Interface Board
JP2
T able B-2 lists the configuration options using either jumpers or 0 Ω s urface-mount resistors.
Table B-2. Interface Board Jumper Configurations
HeaderDescriptionPins Connected
SMODE pins pu l l ed up
JP1Dynamic C Setup
JP2
mini USB Connector Power
Supply Current Limiting
1–2
(Programming Mode)
3–4Reserved for future use
5–6LED DS1 connected
7–8Switch S1 connected
1–2Nominal 700 mA
n.c.Nominal 500 mA
*
Factory
Default
×
×
×
×
* The RCM5600W will operate in Run Mode when these pins are not jumpered.
User’s Manual89
90MiniCore RCM5600W
APPENDIX C. PROTOTYPING BOARD
Appendix C describes the features and accessories of the Prototyping Board, and explains the use of the Prototyping Board to
build prototypes of your own circuits. The Prototyping Board
mounts on the Interface Board from which it receives its power
and signals.
User’s Manual91
C.1 Introduction
The Prototyping Board included in the Development Kit provides a prototyping area for
more advanced hardware development. The Prototyping Board is shown below in
Figure C-1, with its main features identified.
RCM5600W
Module
Extension Header
Power
LED
3.3 V and GND
Buses
Stacking
User Interface
Connector
Through-Hole
Prototyping Area
Figure C-1. Prototyping Board
C.1.1 Prototyping Board Features
SMT Prototyping
Area
• Power Connection—Power is supplied to the Prototyping Board via the RCM5600W
header socket connections.
Power LED—The power LED lights whenever power is connected to the Prototyping
•
Board.
• Module Extension Headers—The complete pin set of the RCM5600W module is
duplicated below header J2. Developers can solder wires directly into the appropriate
holes, or, for more flexible development, a 2 × 25 header strip with a 0.1" pitch can be
soldered into place. See Figure C-4 for the header pinouts.
• Prototyping Area—A generous prototyping area is provided for the installation of
through-hole and surface-mount components. +3.3 V and ground buses run along the
left and right edges of the through-hole prototyping area. The through-hole area is set
up to accept components with a pitch of 0.1" or widths of 0.3" or 0.6". Several areas for
surface-mount devices are also available. (Note that there are SMT pads on both the top
and the bottom of the Prototyping Board.) Each SMT pad is connected to a hole
designed to accept a 30 AWG solid wire.
92MiniCore RCM5600W
C.2 Mechanical Dimensions and Layout
Figure C-2 shows the mechanical dimensions and layout for the Prototyping Board.
dia
0.125
(3.2)
× 4
(4.4)
0.175
(55)
2.15
(64)
2.50
0.15
(3.8)
3.45
(88)
3.75
(95)
Figure C-2. Prototyping Board Dimensions
0.15
(3.8)
(4.4)
0.175
User’s Manual93
Table C-1 lists the electrical, mechanical, and environmental specifications for the Prototyping Board.
Table C-1. Prototyping Board Specifications
ParameterSpecification
Board Size2.50" × 3.75" × 0.52" (64 mm × 95 mm × 13 mm)
Operating Temperature–40°C to +85°C
Humidity5% to 95%, noncondensing
Operating Voltage+3.3 V DC
Current Draw from Interface
Board (excluding user-added
circuits)
2 mA
Prototyping Area
Connectors
Standoffs/Spacers4
1.7" × 2.7" (40 mm × 70 mm) throughhole, 0.1" spacing,
additional space for SMT components
Two 2 × 25 IDC header sockets, 0.1" pitch
(a 2 × 25 IDC header strip is included to connect the Prototyping
Board to the Interface Board below it)
94MiniCore RCM5600W
Loading...
+ hidden pages
You need points to download manuals.
1 point = 1 manual.
You can buy points or you can get point for every manual you upload.