/jenprog

simple Jennic programmer tool

Primary LanguagePython

= Jenprog - programmer for jennic chips =

 Jenprog is a command line driven programmer for jennic Wireless
Microcontrollers. It supports programming through serial interfaces and over
ipv6. Furthermore it has a special mode for Ftdi-Chip Serial board designs that
put the Jennic chip into reset over the DTR/DSR lines.

== Installation ==

  Just run:
 $ python setup.py install

  This should alert if the pyserial package is not installed. You can get it
with:
 $ easy_install pyserial

=== DTR/DSR line ftdi designs ===

 This step is completly optional and you'll only need this if you have a design
that puts the jennic into reset via DTR/DSR lines. For this you need to install
the pyftdi library supplied with this project (please note that this lib has
only been tested under linux):
 $ cd pyftdi/
 $ scons install

 For this command to be succesful, the following projects have to be available:
  - swig (http://www.swig.org)
  - libftdi (http://www.intra2net.com/en/developer/libftdi)
  - scons (http://www.scons.org)

 Using the ftdi connection is completly optional though.

== Usage ==

Usage: jenprog [options] <file>

Options:
  -h, --help            show this help message and exit
  -a ADDR, --address=ADDR
                        start reading at address
  -l LEN, --len=LEN     number of bytes to read
  -m MAC, --mac=MAC     reset the mac addr
  -k KEY, --key=KEY     reset the license key
  -v, --verbose         print send and received packets
  -y, --verify          also verify after writing
  -s, --show            show mac address and license key
  -e, --erase           erasing the flash after reading mac and license key
  -c CONN, --connection=CONN
                        connection implementation (serial,ipv6,ftdi) [default:
                        serial]
  -t TARGET, --target=TARGET
                        target for connection

  Calling jenprog without any file argument will read the contents of the flash
to standard output. Calling it with a file argument will delete the flash and
reprogram with the supplied file.

WORD OF CAUTION:
 * be sure to read your licence key and mac address prior to any attempt to
   reprogram the jennic as it will be deleted and reprogrammed every cycle. So
   if your programming is stopped half-way mac and license key will be lost!
 * there are no sanity on the file itself, jenprog will happily write crap to
   jennics flash memory.

  Standard cycle of reprogramming on linux looks like this:

 $ jenprog -s
 flash: ST M25P10-A
 mac: 0x00158d0000058448 license: 0x000000000000000000000

 $ jenprog my-example-program.hex
 0%..10%..20%..30%..40%..50%..60%..70%..80%..90%..done - 2.55 kb/s - writing mac address and key..done

  For win32 this should be something like:
 $ jenprog -t COM1 my-example-program.hex

=== Putting the Jennic module into programming mode ===

  On certain type of boards you have to put the module into programming mode,
prior to reprogramming the moduls. On the jennic demokit boards this is done by
pressing 'reset' and 'program' together and releasing the 'reset' button prior
to the 'program' button.

  When programming over the ipv6 or ftdi connection this is not needed as
entering the bootloader will be done automatically.

=== Configuring connection ===

  Jenprog supports three ways of connecting to your device. Through serial
ports, ftdi and ipv6. The Type of connection is determined by the '-c'
parameter. The target parameter depends on the chosen connection. For serial
connection this is the serial port to use, for ipv6 this is the ip-address of
your device, for ftdi this is the number of connected devices. Serial connection
is the default, for example to program through the second USB serial connector,
you could use:

 $ jenprog -c /dev/ttyUSB1 <program-file.hex>
 0%..10%..20%..30%..40%..50%..60%..70%..80%..90%..done - 2.55 kb/s - writing mac address and key..done

Programming with a ftdi chip and the DTR line connected to SPIMISO and DSR to
the RESET line works like this:

 $ sudo jenprog -c ftdi <program-file.hex>
 0%..10%..20%..30%..40%..50%..60%..70%..80%..90%..done - 2.55 kb/s - writing mac address and key..done

Using ipv6 works similar to this:

 $ jenprog -c ipv6 -t <ip-address> <program-file.hex>
 0%..10%..20%..30%..40%..50%..60%..70%..80%..90%..done - 5.25 kb/s - writing mac address and key..done

=== Showing/Resetting the mac address and license key ===

 Jennic modules store their ieee802.15.4 mac address in a special region in the
flash. Futhermore the license key for their Zigbee stack can also be found
there. To show them you need to put the Jennic module into programming mode.
Afterwards call jenprog with your configuration with '-s' parameter. For example
over ipv6:

 $ jenprog -c ipv6 -t <ip-address> -s
 flash: ST M25P10-A
 mac: 0x00158d0000058448 license: 0x000000000000000000000

which will output the type of flash this module includes, its mac address and
its license key.


== License ==

Copyright (c) 2011
Telecooperation Office (TecO), Universitaet Karlsruhe (TH), Germany.
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:
1. Redistributions of source code must retain the above copyright
   notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above
   copyright notice, this list of conditions and the following
   disclaimer in the documentation and/or other materials provided
   with the distribution.
3. Neither the name of the Universitaet Karlsruhe (TH) nor the names
   of its contributors may be used to endorse or promote products
   derived from this software without specific prior written
   permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Author(s): Philipp Scholl <scholl@teco.edu>