Difference between revisions of "Programming the Device"

From OpenCircuits
Jump to navigation Jump to search
(programming other devices)
 
(7 intermediate revisions by 3 users not shown)
Line 62: Line 62:
  
 
==Download and Loading Firmware==
 
==Download and Loading Firmware==
 +
===dsPicProgrammer User Guide===
 +
[http://chungyan5.no-ip.org/download/software/dsPicProgrammer/dsPicProgrammerUserGuide_V2.0.1.pdf dsPicProgrammerUserGuide_V2.0.1]
  
 
===Hardware Requirement===
 
===Hardware Requirement===
Line 69: Line 71:
  
 
===Software Requirement===
 
===Software Requirement===
#[http://java.sun.com/javase/downloads/index.jsp JAVA JDK or JRE]
+
#[http://chungyan5.no-ip.org/vc/?root=dspicProgrammer dsPicProgrammer]
#[http://users.frii.com/jarvi/rxtx/download.html RXTX Driver]: Download rxtx-2.1-7-bins-r2.zip or later
 
#[http://chungyan5.no-ip.org/vc/?root=dspicProgrammer dsPicProgrammer] ('''dsPicProgrammer.jar''')
 
  
 
===Files===
 
===Files===
Line 79: Line 79:
  
 
====Setup COM Port====
 
====Setup COM Port====
[[Image:DSC00921.JPG]]
+
[[Image:DSC00921.JPG | 480px]]
 
*Connect your USB-COM converter cable to your computer
 
*Connect your USB-COM converter cable to your computer
 
*Or Using a real COM PORT
 
*Or Using a real COM PORT
  
[[Image:1.jpg]]
+
 
 +
----
 +
=====Find out your COM port Number=====
 +
[[Image:1.jpg | 480px]]
 
*Go to Control Panel \ Device Manager
 
*Go to Control Panel \ Device Manager
  
[[Image:2.jpg]]
+
 
 +
----
 +
[[Image:2.jpg | 480 px]]
 
*Find out your Device COM Port Number
 
*Find out your Device COM Port Number
  
 +
 +
----
 
====Get the Dspic Programmer====
 
====Get the Dspic Programmer====
*Download [http://chungyan5.no-ip.org/open_data/electronic_computer/platforms/dspic/dsPicProgrammer/dsPicProgrammer1.5.5.zip dsPic_Programmer.zip], from [http://chungyan5.no-ip.org/open_data/electronic_computer/platforms/dspic/dsPicProgrammer/ws/ updated directory] or [http://chungyan5.no-ip.org/vc svn server]
+
[[Image:programmer_3.jpg |480px]]
*Save to a directory.
+
*Download [http://chungyan5.no-ip.org/open_data/electronic_computer/platforms/dspic/dsPicProgrammer/dsPicProgrammer3.00.01s.zip dsPicProgrammer.zip], from [http://chungyan5.no-ip.org/open_data/electronic_computer/platforms/dspic/dsPicProgrammer/ws/ updated directory] or [http://chungyan5.no-ip.org/vc svn server]
::e.g. desktop
+
*Unzip the dsPicProgrammer.zip, then you have an unziped file.
*Unzip the dsPic_Programmer.zip, then you have an unziped file.
+
 
[[Image:prog_guid_dl.JPG]]
+
 
 +
----
 +
====Download Firmware====
 +
[[Image:programmer_4.jpg |480px]]
 +
*Save your .hex file(foo.hex) to the folder called firmware.
 +
*Run dsPicProgrammer.bat (Windows) / dsPicProgrammer.sh (linux)
 +
**Make sure your device is connected through a "Direct RS232 Cable" to PC Serial Port.
 +
 
 +
 
 +
----
 +
[[Image:programmer_6.jpg |480px]]
 +
*Choose a COM port
 +
*Choose a baudrate
 +
::115200 is communication speed [in bps]
 +
 
  
 
----
 
----
 +
[[Image:programmer_7.jpg |480px]]
 +
*Choose a .hex file
  
*Drag the unzip file to a directory.
 
::e.g. USB memory devices
 
[[Image:prog_guid_drag.JPG]]
 
  
 
----
 
----
 +
[[Image:programmer_8.jpg |480px]]
 +
*Press start
 +
*Then press Yes to confirm programming the device
  
*Save your .hex file(foo.hex) to your directory location 
 
::e.g. X:\dsPic_Programmer\ ---> X:\ is the driver where the dsPic_Programmer located
 
[[Image:prog_guid_hex.JPG]]
 
  
====Download Firmware====
+
 
*Start a Command Prompt
+
----
**Start -> Run<br>[[Image:2 1 run.JPG]]<br>
+
[[Image:programmer_9.jpg | 480px]]
**Enter cmd<br>[[Image:2 2 cmd.JPG]]<br>
+
*The status during programming
*Run dsPicProgrammer
 
**Make sure your device is connected through a "Direct RS232 Cable" to PC Serial Port.
 
**Change to the directory where dsPicProgrammer.jar is located and run the command, for example:
 
***Windows
 
****'''jre\bin\java -Djava.library.path=.\rxtx\bin -jar dspicProgrammer.jar COM1 115200 foo.hex''' or
 
****'''dsPicProgrammer.bat COM1 115200 foo.hex'''
 
***Linux
 
****'''java -Djava.library.path=./rxtx/bin -jar dsPicProgrammer.jar /dev/ttyS0 115200 foo.hex''' or
 
****'''dsPicProgrammer.sh /dev/ttyS0 115200 foo.hex'''
 
**Legend:
 
:::COM1 is your COM Port ID
 
:::115200 is communication speed [in bps]
 
:::foo.hex is your firmware new file
 
::[[Image:5.jpg]]
 
:*When the program prompt you for an input, press y:<br>[[Image:2 4 prompt.JPG]]<br>
 
:*If communication can be established, you should see something like this:<br>[[Image:2 5 progress.JPG]]<br>
 
:*Wait until programming is completed.<br>[[Image:2 6 complete.JPG]]<br>
 
:*after all completed, power OFF your device, then power ON again, enjoy your new updated.
 
  
  
 +
----
 +
[[Image:programmer_10.jpg |480px]]
 +
*The programming have been completed, press OK the close the message box
 +
 +
----
 
===Troubleshooting===
 
===Troubleshooting===
 
====Invalid COM Port====
 
====Invalid COM Port====

Latest revision as of 23:29, 25 April 2012

Description on how to use dsPicProgrammer to download firmware to DsPIC30F 5011 Development Board

Loading Bootloader (Once only)[edit]

Hardware Requirement[edit]

  1. PC with USB port (with Windows)
  2. ICD2 Programmer
  3. Target Board
  4. 5V Power Supply

Software Requirement[edit]

  1. MPLAB IDE v7.50: v7.60 is not compatible with our current ICD2 Programmers. There are consistent "Devices cannot be founded" warnings. See manual for details.

Files[edit]

  1. dsPicBootloader (bl_$(MODEL).hex).

Procedure[edit]

Loading Bootloader
Step Remarks
Install MPLAB IDE
  • Do NOT connect ICD 2 (via USB) to PC
  • Execute MPLAB vX.XX Install.exe
Install USB Driver
  • Follow the instruction in (C:\Program Files\Microchip\MPLAB IDE\ICD2\Drivers\Ddicd2.htm)
Select Target Chip
  • Run MPLAB IDE on PC
  • Select: Configure>Select Devices...
  • Choose the correct dsPic model
Load Bootloader
  • Select: File>Import...
  • Select bl_$(MODEL).hex
ICD 2 <-> PC
  • Plug-in ICD 2 to PC via USB cable
Target <-> ICD 2
  • Connect six pin cable to target board. Beware of the pin assignments. Only pin 1 - 5 are used.
  • Power-up the target.
ICD 2 <-> PC
  • Select: Programmer>Select Programmer>MPLAB ICD 2
  • If this is the first time the ICD 2 is connected to PC, MPLAB IDE will automatically download the required OS to ICD 2, wait until it has finished
  • If you have not connected and powered up the target, you might see Warnings on invalid device IDs, and/or running self tests.
  • See results of self test if necessary: Programmer>Settings, Status Tab. Refer to ICD2 User's Guide Chapter 7.
Start Programming
  • Select: Programmer>Program
  • Wait until finishes
Finishing
  • Power-down the Target
  • Select: Programmer>Select Programmer>None
  • Unplug USB cable


Download and Loading Firmware[edit]

dsPicProgrammer User Guide[edit]

dsPicProgrammerUserGuide_V2.0.1

Hardware Requirement[edit]

  1. PC (Linux/Windows) with COM Port OR USB-COM converter cable
  2. Target Board (with bootloader)
  3. 5V Power Supply

Software Requirement[edit]

  1. dsPicProgrammer

Files[edit]

  1. Application hex file (e.g. app.hex)

Procedure[edit]

Setup COM Port[edit]

DSC00921.JPG

  • Connect your USB-COM converter cable to your computer
  • Or Using a real COM PORT



Find out your COM port Number[edit]

1.jpg

  • Go to Control Panel \ Device Manager



2.jpg

  • Find out your Device COM Port Number



Get the Dspic Programmer[edit]

Programmer 3.jpg



Download Firmware[edit]

Programmer 4.jpg

  • Save your .hex file(foo.hex) to the folder called firmware.
  • Run dsPicProgrammer.bat (Windows) / dsPicProgrammer.sh (linux)
    • Make sure your device is connected through a "Direct RS232 Cable" to PC Serial Port.



Programmer 6.jpg

  • Choose a COM port
  • Choose a baudrate
115200 is communication speed [in bps]



Programmer 7.jpg

  • Choose a .hex file



Programmer 8.jpg

  • Press start
  • Then press Yes to confirm programming the device



Programmer 9.jpg

  • The status during programming



Programmer 10.jpg

  • The programming have been completed, press OK the close the message box

Troubleshooting[edit]

Invalid COM Port[edit]

  • In case of selecting an invalid COM port, you should see the error message:
    gnu.io.NoSuchPortException: Choosing COM Port Error
    3 1 com err.JPG

  • Solution: check the COM port ID, or close any programs that are using the COM Port

Missing firmware file[edit]

  • In case of selecting a firmware file that does not exist, you should see the error message:
    java.io.FileNotFoundException: foo1.hex <The system cannot find the file specified>
    3 2 file err.JPG

  • Solution: check the file path

Missing RXTX driver[edit]

  • In case of missing the RXTX driver, you should see the error message:
    Exception in thread “main” java.lang.NoClassDefFoundError: gnu/io/UnsupportedCommOperationException
    3 3 rxtx err.JPG

  • Solution:
    • Copy RXTXcomm.jar to /dsPicProgrammer/rxtx/lib
    • Copy rxtxSerial.dll to /dsPicProgrammer/rxtx/bin (Window)
    • Copy librxtxSerial.so to /dsPicProgrammer/rxtx/bin (Linux)

Missing JAVA[edit]

  • In case of missing JAVA JDK or JRE, an error message will be prompted.
  • Solution:
    • Copy the contents under directory C:/Program Files/Java/jre$(VERSION)/ to /dsPicProgrammer/jre

Further reading[edit]