Difference between revisions of "Example io demo"

From wiki.emacinc.com
Jump to: navigation, search
(Usage Example. A/D Demo)
(Hardware Requirements)
Line 20: Line 20:
 
To use the '''io demo''' program you will need the following hardware.
 
To use the '''io demo''' program you will need the following hardware.
  
* An EMAC carrier board: [http://www.emacinc.com/som/som150es.htm SOM-150ES], [http://www.emacinc.com/som/som200es.htm SOM-200ES], [http://www.emacinc.com/som/som210es.htm SOM-210ES], [http://www.emacinc.com/som/som212es.htm SOM-212ES] or [http://www.emacinc.com/som/som250es.htm SOM-250ES].<br />
+
* An EMAC [http://www.emacinc.com/som/som150es.htm SOM-150ES] carrier board. <br />
 
* A compatible EMAC SoM for that carrier board ([http://www.emacinc.com/products/system_on_module/SoM-9260M SOM-9260M], [http://www.emacinc.com/products/system_on_module/som-9G20m SOM-9G20M] and [http://www.emacinc.com/products/system_on_module/som-9x25 SOM-9X25] are all compatible and available from EMAC).<br />
 
* A compatible EMAC SoM for that carrier board ([http://www.emacinc.com/products/system_on_module/SoM-9260M SOM-9260M], [http://www.emacinc.com/products/system_on_module/som-9G20m SOM-9G20M] and [http://www.emacinc.com/products/system_on_module/som-9x25 SOM-9X25] are all compatible and available from EMAC).<br />
 
* A multimeter or oscilloscope. See [http://wikidev.emacinc.com/wiki/Example_io_demo#Usage_Example._Input_to_Output_Demo Usage Example. Input to Output Demo] and  [http://wikidev.emacinc.com/wiki/Example_io_demo#Usage_Example._Count_Demo Usage Example. Count Demo] for details.<br />
 
* A multimeter or oscilloscope. See [http://wikidev.emacinc.com/wiki/Example_io_demo#Usage_Example._Input_to_Output_Demo Usage Example. Input to Output Demo] and  [http://wikidev.emacinc.com/wiki/Example_io_demo#Usage_Example._Count_Demo Usage Example. Count Demo] for details.<br />

Revision as of 13:15, 3 January 2014

TODO: {{#todo:InProgress(12.05.13-12:47->JG+)|Jgreene|oe 4,oe 5,jg,md,Review}}

This is a guide to the io demo C example project included in the EMAC OE SDK.

The io_demo project provides four examples of carrier board IO:

  • An analog-to-digital converter demo.
  • A counter demo.
  • An input-to-output demo.
  • A ring demo.

The io_demo project builds one executable: io_demo.

Opening, Building and Uploading the Project Files

stub

Usage and Behaviour

Hardware Requirements

To use the io demo program you will need the following hardware.

Know Your Carrier Board

TODO do this with just 1 board picture (and one or two diagrams). indicate GPIO, LEDs, analog IO

HEY MIKE, I COULD HAVE PICTURES OF ALL THE CARRIER BOARDS WITH ALL THE RELEVANT STUFF LABELLED (WITH ARROWS ETC). WHAT DO YOU THINK?

File:Som150 with SoM.jpg
This is a SOM-150ES carrier board carrying a SoM


File:PortABC gpio header and LEDs location.jpg
This is the SOM-150ES that we used for testing. Other carrier boards will have a similar layout.


Gpio header detail.png

Usage for io_demo

Run io demo from the console. It takes no parameters.

 ./io_demo

This brings up a menu of demos.

****************************
     Demo Menu              
                            
A/D Demo             - a    
Count Demo           - c    
Input to Output Demo - i    
Ring Demo            - r    
                            
Exit                 - x    
                            
Enter Selection:

Now we can press a, c, i or r to run a demo; or x to exit.

Usage Example. A/D Demo

From the demo menu press -a.

did somebody say something about there already being an analog out built right onto the carrier board?

Usage Example. Count Demo

From the demo menu press c.

The system counts from 0 to 255 in binary. It takes about 15 seconds to complete.
The steps of this process are reflected in the GPIO PortC header pins (see Know Your Carrier Board, above). As each bit in our 8bit register is set to 1, the corresponding pin in the PortC header momentarily registers 5 volts (easily detected with a multimeter or oscilloscope).

More visibly, the counting process is also reflected in the strip of 8 LEDs on the board (LD1-LD8. see Know Your Carrier Board, above). A lit LED indicates a 1 in our 8 bit register and an unlit LED indicates a 0. When the counting process is finished all 8 LEDs are lit (255).

Usage Example. Input to Output Demo

In this usage example the carrier board talks to itself. We send an 8bit data stream directly from Port B to Port C via a short piece of ribbon cable.

<detail of board. gpio header closeup with ports b and c labelled>

This is the ribbon cable that we made for our input-to-output demo. Note that we connect PortC:pin0 to PortB:pin0; PortC:pin1 to PortB:pin1; etc.
Iodemo homemaderibboncable.jpg

Here's our cable plugged into the GPIO header. You see that PortC:pin0 outputs to PortB:pin0; PortC:pin1 outputs to PortB:pin1; etc. Iodemo homemaderibboncable closeup.jpg

Our data stream for each pin is 1,0,1,0,1,0... That is to say: all pins are set to 1, then they are all set to 0, then to 1 again, etc. We observe our data stream in the strip of 8 LEDs on the carrier board. They blink in unison.

Note The blinking may get a little out of synch after a few seconds. This is normal.

Usage Example. Ring Demo

Refer to the SOM-150ES carrier board surface mount LEDs LD1-LD8 for output.

500px

The board lights the LEDs in numeric sequence, 1-8, then repeats; looping until a key is pressed.