README 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. By Vlad Lungu vlad.lungu@windriver.com 2007-Oct-01
  2. ----------------------------------------
  3. Qemu is a full system emulator. See
  4. http://www.nongnu.org/qemu/
  5. Limitations & comments
  6. ----------------------
  7. Supports the "-m mips" configuration of qemu: serial,NE2000,IDE.
  8. Support is big endian only for now (or at least this is what I tested).
  9. Derived from au1x00 with a lot of things cut out.
  10. Supports emulated flash (patch Jean-Christophe PLAGNIOL-VILLARD) with
  11. recent qemu versions. When using emulated flash, launch with
  12. -pflash <filename> and erase mips_bios.bin.
  13. Notes for the Qemu MIPS port
  14. ----------------------------
  15. I) Example usage:
  16. # ln -s u-boot.bin mips_bios.bin
  17. start it:
  18. qemu-system-mips -L . /dev/null -nographic
  19. or
  20. if you use a qemu version after commit 4224
  21. create image:
  22. # dd of=flash bs=1k count=4k if=/dev/zero
  23. # dd of=flash bs=1k conv=notrunc if=u-boot.bin
  24. start it:
  25. # qemu-system-mips -M mips -pflash flash -monitor null -nographic
  26. 2) Download kernel + initrd
  27. On ftp://ftp.denx.de/pub/contrib/Jean-Christophe_Plagniol-Villard/qemu_mips/
  28. you can downland
  29. #config to build the kernel
  30. qemu_mips_defconfig
  31. #patch to fix mips interrupt init on 2.6.24.y kernel
  32. qemu_mips_kernel.patch
  33. initrd.gz
  34. vmlinux
  35. vmlinux.bin
  36. System.map
  37. 4) Generate uImage
  38. # tools/mkimage -A mips -O linux -T kernel -C gzip -a 0x80010000 -e 0x80245650 -n "Linux 2.6.24.y" -d vmlinux.bin.gz uImage
  39. 5) Copy uImage to Flash
  40. # dd if=uImage bs=1k conv=notrunc seek=224 of=flash
  41. 6) Generate Ide Disk
  42. # dd of=ide bs=1k cout=100k if=/dev/zero
  43. # sfdisk -C 261 -d ide
  44. # partition table of ide
  45. unit: sectors
  46. ide1 : start= 63, size= 32067, Id=83
  47. ide2 : start= 32130, size= 32130, Id=83
  48. ide3 : start= 64260, size= 4128705, Id=83
  49. ide4 : start= 0, size= 0, Id= 0
  50. 7) Copy to ide
  51. # dd if=uImage bs=512 conv=notrunc seek=63 of=ide
  52. 8) Generate ext2 on part 2 on Copy uImage and initrd.gz
  53. # Attached as loop device ide offset = 32130 * 512
  54. # losetup -o 16450560 -f ide
  55. # Format as ext2 ( arg2 : nb blocks)
  56. # mke2fs /dev/loop0 16065
  57. # losetup -d /dev/loop0
  58. # Mount and copy uImage and initrd.gz to it
  59. # mount -o loop,offset=16450560 -t ext2 ide /mnt
  60. # mkdir /mnt/boot
  61. # cp {initrd.gz,uImage} /mnt/boot/
  62. # Umount it
  63. # umount /mnt
  64. 9) Set Environment
  65. setenv rd_start 0x80800000
  66. setenv rd_size 2663940
  67. setenv kernel BFC38000
  68. setenv oad_addr 80500000
  69. setenv load_addr2 80F00000
  70. setenv kernel_flash BFC38000
  71. setenv load_addr_hello 80200000
  72. setenv bootargs 'root=/dev/ram0 init=/bin/sh'
  73. setenv load_rd_ext2 'ide res; ext2load ide 0:2 ${rd_start} /boot/initrd.gz'
  74. setenv load_rd_tftp 'tftp ${rd_start} /initrd.gz'
  75. setenv load_kernel_hda 'ide res; diskboot ${load_addr} 0:2'
  76. setenv load_kernel_ext2 'ide res; ext2load ide 0:2 ${load_addr} /boot/uImage'
  77. setenv load_kernel_tftp 'tftp ${load_addr} /qemu_mips/uImage'
  78. setenv boot_ext2_ext2 'run load_rd_ext2; run load_kernel_ext2; run addmisc; bootm ${load_addr}'
  79. setenv boot_ext2_flash 'run load_rd_ext2; run addmisc; bootm ${kernel_flash}'
  80. setenv boot_ext2_hda 'run load_rd_ext2; run load_kernel_hda; run addmisc; bootm ${load_addr}'
  81. setenv boot_ext2_tftp 'run load_rd_ext2; run load_kernel_tftp; run addmisc; bootm ${load_addr}'
  82. setenv boot_tftp_hda 'run load_rd_tftp; run load_kernel_hda; run addmisc; bootm ${load_addr}'
  83. setenv boot_tftp_ext2 'run load_rd_tftp; run load_kernel_ext2; run addmisc; bootm ${load_addr}'
  84. setenv boot_tftp_flash 'run load_rd_tftp; run addmisc; bootm ${kernel_flash}'
  85. setenv boot_tftp_tftp 'run load_rd_tftp; run load_kernel_tftp; run addmisc; bootm ${load_addr}'
  86. setenv load_hello_tftp 'tftp ${load_addr_hello} /examples/hello_world.bin'
  87. setenv go_tftp 'run load_hello_tftp; go ${load_addr_hello}'
  88. setenv addmisc 'setenv bootargs ${bootargs} console=ttyS0,${baudrate} rd_start=${rd_start} rd_size=${rd_size} ethaddr=${ethaddr}'
  89. setenv bootcmd 'run boot_tftp_flash'
  90. 10) Now you can boot from flash, ide, ide+ext2 and tfp
  91. # qemu-system-mips -M mips -pflash flash -monitor null -nographic -net nic -net user -tftp `pwd` -hda ide
  92. II) How to debug U-Boot
  93. In order to debug U-Boot you need to start qemu with gdb server support (-s)
  94. and waiting the connection to start the CPU (-S)
  95. # qemu-system-mips -S -s -M mips -pflash flash -monitor null -nographic -net nic -net user -tftp `pwd` -hda ide
  96. in an other console you start gdb
  97. 1) Debugging of U-Boot Before Relocation
  98. Before relocation, the addresses in the ELF file can be used without any problems
  99. by connecting to the gdb server localhost:1234
  100. # mipsel-unknown-linux-gnu-gdb u-boot
  101. GNU gdb 6.6
  102. Copyright (C) 2006 Free Software Foundation, Inc.
  103. GDB is free software, covered by the GNU General Public License, and you are
  104. welcome to change it and/or distribute copies of it under certain conditions.
  105. Type "show copying" to see the conditions.
  106. There is absolutely no warranty for GDB. Type "show warranty" for details.
  107. This GDB was configured as "--host=i486-linux-gnu --target=mipsel-unknown-linux-gnu"...
  108. (gdb) target remote localhost:1234
  109. Remote debugging using localhost:1234
  110. _start () at start.S:64
  111. 64 RVECENT(reset,0) /* U-boot entry point */
  112. Current language: auto; currently asm
  113. (gdb) b board.c:289
  114. Breakpoint 1 at 0xbfc00cc8: file board.c, line 289.
  115. (gdb) c
  116. Continuing.
  117. Breakpoint 1, board_init_f (bootflag=<value optimized out>) at board.c:290
  118. 290 relocate_code (addr_sp, id, addr);
  119. Current language: auto; currently c
  120. (gdb) p/x addr
  121. $1 = 0x87fa0000
  122. 2) Debugging of U-Boot After Relocation
  123. For debugging U-Boot after relocation we need to know the address to which
  124. U-Boot relocates itself to 0x87fa0000 by default.
  125. And replace the symbol table to this offset.
  126. (gdb) symbol-file
  127. Discard symbol table from `/private/u-boot-arm/u-boot'? (y or n) y
  128. Error in re-setting breakpoint 1:
  129. No symbol table is loaded. Use the "file" command.
  130. No symbol file now.
  131. (gdb) add-symbol-file u-boot 0x87fa0000
  132. add symbol table from file "u-boot" at
  133. .text_addr = 0x87fa0000
  134. (y or n) y
  135. Reading symbols from /private/u-boot-arm/u-boot...done.
  136. Breakpoint 1 at 0x87fa0cc8: file board.c, line 289.
  137. (gdb) c
  138. Continuing.
  139. Program received signal SIGINT, Interrupt.
  140. 0xffffffff87fa0de4 in udelay (usec=<value optimized out>) at time.c:78
  141. 78 while ((tmo - read_c0_count()) < 0x7fffffff)