Difference between revisions of "Linux Debug"

From ArmadeusWiki
Jump to: navigation, search
m (Changing processor registers from Linux user space with imxregs)
(board independant)
Line 3: Line 3:
 
==Introduction==
 
==Introduction==
  
On this page, you will find usefull informations for debugging Armadeus under Linux
+
On this page, you will find usefull informations for debugging your Linux kernel/drivers.
  
 
==Testing your custom Linux kernel before flashing it==
 
==Testing your custom Linux kernel before flashing it==
Line 9: Line 9:
 
You can test a linux kernel you've generated without having to reflash your board and destroy your currently working image.
 
You can test a linux kernel you've generated without having to reflash your board and destroy your currently working image.
 
Indeed Linux kernel images can be loaded and started from SDRAM with U-Boot:
 
Indeed Linux kernel images can be loaded and started from SDRAM with U-Boot:
  BIOS> tftp 8000000 apf9328-linux.bin
+
<pre class="apf">
  BIOS> bootm 8000000
+
  BIOS> tftp ${loadaddr} ${board_name}-linux.bin
 +
  BIOS> bootm ${loadaddr}
 +
</pre>
  
 
==Changing processor registers from Linux user space with imxregs==
 
==Changing processor registers from Linux user space with imxregs==
  
This tool allows you to access i.MXL registers from Linux userspace/console. This way you debug your driver or access i.MXL hardware functionnalities directly from Linux console.
+
This tool allows you to access i.MX registers from Linux userspace/console. This way you debug your driver or access i.MX hardware functionnalities directly from Linux console.
  
 
* First, you have to enable this tool in Buildroot (package selection for target -> Hardware handling / blockdevices and filesystem maintenance ->  imxregs):
 
* First, you have to enable this tool in Buildroot (package selection for target -> Hardware handling / blockdevices and filesystem maintenance ->  imxregs):
 +
<pre class="host">
 
  $ make menuconfig
 
  $ make menuconfig
 +
</pre>
  
 
Once done, compile it:
 
Once done, compile it:
 +
<pre class="host">
 
  $ make
 
  $ make
 +
</pre>
  
The generated file is located in buildroot/build_armv4t/imxregs-1.0/. Now you can copy it on your target.
+
The generated file is located in $ARMADEUS_ROOTFS_DIR/usr/bin/. You can copy it directly on your target or reflash your rootfs.
  
* To use it, you must clear i.MXL PAR_1 & PAR_2 registers (registers access rights) '''before''' launching Linux kernel, so in U-Boot type:
+
* To use it, you must clear i.MX PAR_1 & PAR_2 registers (registers access rights) '''before''' launching Linux kernel, so in U-Boot type (example here is for APF9328):
 +
<pre class="apf">
 
  BIOS> mw.l 0x00200008 0
 
  BIOS> mw.l 0x00200008 0
 
  BIOS> mw.l 0x00210008 0
 
  BIOS> mw.l 0x00210008 0
 +
</pre>
  
If you use it frequently, you can define a small script in U-Boot:
+
If you use it frequently, a small script ''unlock_regs'' has been defined in U-Boot, and you can call before launching your kernel:
BIOS> setenv unlock_regs mw.l 0x00200008 0\; mw.l 0x00210008 0
+
<pre class="apf">
BIOS> saveenv
+
and call it like that before launching your kernel:
+
 
  BIOS> run unlock_regs
 
  BIOS> run unlock_regs
 +
</pre>
  
 
* Then in Linux console/terminal, launch ''imxregs'' like that:
 
* Then in Linux console/terminal, launch ''imxregs'' like that:
 +
<pre class="apf">
 
  # imxregs REGISTER_NAME  (give it the register name as printed in iMX Ref Manual or just the begining of the name)
 
  # imxregs REGISTER_NAME  (give it the register name as printed in iMX Ref Manual or just the begining of the name)
 +
</pre>
 
or
 
or
 +
<pre class="apf">
 
  # imxregs    (to dump all supported registers)
 
  # imxregs    (to dump all supported registers)
 +
</pre>
  
 
===Examples:===
 
===Examples:===
 
* Show OCR1 registers of each GPIO Port:
 
* Show OCR1 registers of each GPIO Port:
 +
<pre class="apf">
 
  # imxregs OCR1
 
  # imxregs OCR1
 +
</pre>
  
 
* Write 0x00000123 to OCR1_D register:
 
* Write 0x00000123 to OCR1_D register:
 +
<pre class="apf">
 
  # imxregs OCR1_D 123
 
  # imxregs OCR1_D 123
 +
</pre>
  
 
==Changing FPGA IP's registers from Linux user space with fpgaregs==
 
==Changing FPGA IP's registers from Linux user space with fpgaregs==
Line 54: Line 69:
 
* http://tree.celinuxforum.org/CelfPubWiki/PatchArchive
 
* http://tree.celinuxforum.org/CelfPubWiki/PatchArchive
  
<br>[[Image:FrenchFlag.png]][[Fr:Débogage Linux| Cette page en français]]
+
{{LanguageBar|Linux_Debug|Débogage Linux|Linux_Debug}}

Revision as of 08:57, 15 April 2009

Tips to do debugging under Linux.

Introduction

On this page, you will find usefull informations for debugging your Linux kernel/drivers.

Testing your custom Linux kernel before flashing it

You can test a linux kernel you've generated without having to reflash your board and destroy your currently working image. Indeed Linux kernel images can be loaded and started from SDRAM with U-Boot:

 BIOS> tftp ${loadaddr} ${board_name}-linux.bin
 BIOS> bootm ${loadaddr}

Changing processor registers from Linux user space with imxregs

This tool allows you to access i.MX registers from Linux userspace/console. This way you debug your driver or access i.MX hardware functionnalities directly from Linux console.

  • First, you have to enable this tool in Buildroot (package selection for target -> Hardware handling / blockdevices and filesystem maintenance -> imxregs):
 $ make menuconfig

Once done, compile it:

 $ make

The generated file is located in $ARMADEUS_ROOTFS_DIR/usr/bin/. You can copy it directly on your target or reflash your rootfs.

  • To use it, you must clear i.MX PAR_1 & PAR_2 registers (registers access rights) before launching Linux kernel, so in U-Boot type (example here is for APF9328):
 BIOS> mw.l 0x00200008 0
 BIOS> mw.l 0x00210008 0

If you use it frequently, a small script unlock_regs has been defined in U-Boot, and you can call before launching your kernel:

 BIOS> run unlock_regs
  • Then in Linux console/terminal, launch imxregs like that:
 # imxregs REGISTER_NAME  (give it the register name as printed in iMX Ref Manual or just the begining of the name)

or

 # imxregs    (to dump all supported registers)

Examples:

  • Show OCR1 registers of each GPIO Port:
 # imxregs OCR1
  • Write 0x00000123 to OCR1_D register:
 # imxregs OCR1_D 123

Changing FPGA IP's registers from Linux user space with fpgaregs

see FPGA_register

Links

Other languages:

English Flag.svg English  •  French Flag.svg Français