README.sandbox 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399
  1. /*
  2. * Copyright (c) 2014 The Chromium OS Authors.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. Native Execution of U-Boot
  7. ==========================
  8. The 'sandbox' architecture is designed to allow U-Boot to run under Linux on
  9. almost any hardware. To achieve this it builds U-Boot (so far as possible)
  10. as a normal C application with a main() and normal C libraries.
  11. All of U-Boot's architecture-specific code therefore cannot be built as part
  12. of the sandbox U-Boot. The purpose of running U-Boot under Linux is to test
  13. all the generic code, not specific to any one architecture. The idea is to
  14. create unit tests which we can run to test this upper level code.
  15. CONFIG_SANDBOX is defined when building a native board.
  16. The board name is 'sandbox' but the vendor name is unset, so there is a
  17. single board in board/sandbox.
  18. CONFIG_SANDBOX_BIG_ENDIAN should be defined when running on big-endian
  19. machines.
  20. By default sandbox builds and runs on 64-bit hosts. If you are going to build
  21. and run sandbox on a 32-bit host, select CONFIG_SANDBOX_32BIT.
  22. Note that standalone/API support is not available at present.
  23. Basic Operation
  24. ---------------
  25. To run sandbox U-Boot use something like:
  26. make sandbox_defconfig all
  27. ./u-boot
  28. Note:
  29. If you get errors about 'sdl-config: Command not found' you may need to
  30. install libsdl1.2-dev or similar to get SDL support. Alternatively you can
  31. build sandbox without SDL (i.e. no display/keyboard support) by removing
  32. the CONFIG_SANDBOX_SDL line in include/configs/sandbox.h or using:
  33. make sandbox_defconfig all NO_SDL=1
  34. ./u-boot
  35. U-Boot will start on your computer, showing a sandbox emulation of the serial
  36. console:
  37. U-Boot 2014.04 (Mar 20 2014 - 19:06:00)
  38. DRAM: 128 MiB
  39. Using default environment
  40. In: serial
  41. Out: lcd
  42. Err: lcd
  43. =>
  44. You can issue commands as your would normally. If the command you want is
  45. not supported you can add it to include/configs/sandbox.h.
  46. To exit, type 'reset' or press Ctrl-C.
  47. Console / LCD support
  48. ---------------------
  49. Assuming that CONFIG_SANDBOX_SDL is defined when building, you can run the
  50. sandbox with LCD and keyboard emulation, using something like:
  51. ./u-boot -d u-boot.dtb -l
  52. This will start U-Boot with a window showing the contents of the LCD. If
  53. that window has the focus then you will be able to type commands as you
  54. would on the console. You can adjust the display settings in the device
  55. tree file - see arch/sandbox/dts/sandbox.dts.
  56. Command-line Options
  57. --------------------
  58. Various options are available, mostly for test purposes. Use -h to see
  59. available options. Some of these are described below.
  60. The terminal is normally in what is called 'raw-with-sigs' mode. This means
  61. that you can use arrow keys for command editing and history, but if you
  62. press Ctrl-C, U-Boot will exit instead of handling this as a keypress.
  63. Other options are 'raw' (so Ctrl-C is handled within U-Boot) and 'cooked'
  64. (where the terminal is in cooked mode and cursor keys will not work, Ctrl-C
  65. will exit).
  66. As mentioned above, -l causes the LCD emulation window to be shown.
  67. A device tree binary file can be provided with -d. If you edit the source
  68. (it is stored at arch/sandbox/dts/sandbox.dts) you must rebuild U-Boot to
  69. recreate the binary file.
  70. To execute commands directly, use the -c option. You can specify a single
  71. command, or multiple commands separated by a semicolon, as is normal in
  72. U-Boot. Be careful with quoting as the shall will normally process and
  73. swallow quotes. When -c is used, U-Boot exists after the command is complete,
  74. but you can force it to go to interactive mode instead with -i.
  75. Memory Emulation
  76. ----------------
  77. Memory emulation is supported, with the size set by CONFIG_SYS_SDRAM_SIZE.
  78. The -m option can be used to read memory from a file on start-up and write
  79. it when shutting down. This allows preserving of memory contents across
  80. test runs. You can tell U-Boot to remove the memory file after it is read
  81. (on start-up) with the --rm_memory option.
  82. To access U-Boot's emulated memory within the code, use map_sysmem(). This
  83. function is used throughout U-Boot to ensure that emulated memory is used
  84. rather than the U-Boot application memory. This provides memory starting
  85. at 0 and extending to the size of the emulation.
  86. Storing State
  87. -------------
  88. With sandbox you can write drivers which emulate the operation of drivers on
  89. real devices. Some of these drivers may want to record state which is
  90. preserved across U-Boot runs. This is particularly useful for testing. For
  91. example, the contents of a SPI flash chip should not disappear just because
  92. U-Boot exits.
  93. State is stored in a device tree file in a simple format which is driver-
  94. specific. You then use the -s option to specify the state file. Use -r to
  95. make U-Boot read the state on start-up (otherwise it starts empty) and -w
  96. to write it on exit (otherwise the stored state is left unchanged and any
  97. changes U-Boot made will be lost). You can also use -n to tell U-Boot to
  98. ignore any problems with missing state. This is useful when first running
  99. since the state file will be empty.
  100. The device tree file has one node for each driver - the driver can store
  101. whatever properties it likes in there. See 'Writing Sandbox Drivers' below
  102. for more details on how to get drivers to read and write their state.
  103. Running and Booting
  104. -------------------
  105. Since there is no machine architecture, sandbox U-Boot cannot actually boot
  106. a kernel, but it does support the bootm command. Filesystems, memory
  107. commands, hashing, FIT images, verified boot and many other features are
  108. supported.
  109. When 'bootm' runs a kernel, sandbox will exit, as U-Boot does on a real
  110. machine. Of course in this case, no kernel is run.
  111. It is also possible to tell U-Boot that it has jumped from a temporary
  112. previous U-Boot binary, with the -j option. That binary is automatically
  113. removed by the U-Boot that gets the -j option. This allows you to write
  114. tests which emulate the action of chain-loading U-Boot, typically used in
  115. a situation where a second 'updatable' U-Boot is stored on your board. It
  116. is very risky to overwrite or upgrade the only U-Boot on a board, since a
  117. power or other failure will brick the board and require return to the
  118. manufacturer in the case of a consumer device.
  119. Supported Drivers
  120. -----------------
  121. U-Boot sandbox supports these emulations:
  122. - Block devices
  123. - Chrome OS EC
  124. - GPIO
  125. - Host filesystem (access files on the host from within U-Boot)
  126. - I2C
  127. - Keyboard (Chrome OS)
  128. - LCD
  129. - Network
  130. - Serial (for console only)
  131. - Sound (incomplete - see sandbox_sdl_sound_init() for details)
  132. - SPI
  133. - SPI flash
  134. - TPM (Trusted Platform Module)
  135. A wide range of commands is implemented. Filesystems which use a block
  136. device are supported.
  137. Also sandbox supports driver model (CONFIG_DM) and associated commands.
  138. Linux RAW Networking Bridge
  139. ---------------------------
  140. The sandbox_eth_raw driver bridges traffic between the bottom of the network
  141. stack and the RAW sockets API in Linux. This allows much of the U-Boot network
  142. functionality to be tested in sandbox against real network traffic.
  143. For Ethernet network adapters, the bridge utilizes the RAW AF_PACKET API. This
  144. is needed to get access to the lowest level of the network stack in Linux. This
  145. means that all of the Ethernet frame is included. This allows the U-Boot network
  146. stack to be fully used. In other words, nothing about the Linux network stack is
  147. involved in forming the packets that end up on the wire. To receive the
  148. responses to packets sent from U-Boot the network interface has to be set to
  149. promiscuous mode so that the network card won't filter out packets not destined
  150. for its configured (on Linux) MAC address.
  151. The RAW sockets Ethernet API requires elevated privileges in Linux. You can
  152. either run as root, or you can add the capability needed like so:
  153. sudo /sbin/setcap "CAP_NET_RAW+ep" /path/to/u-boot
  154. The default device tree for sandbox includes an entry for eth0 on the sandbox
  155. host machine whose alias is "eth1". The following are a few examples of network
  156. operations being tested on the eth0 interface.
  157. sudo /path/to/u-boot -D
  158. DHCP
  159. ....
  160. set autoload no
  161. set ethact eth1
  162. dhcp
  163. PING
  164. ....
  165. set autoload no
  166. set ethact eth1
  167. dhcp
  168. ping $gatewayip
  169. TFTP
  170. ....
  171. set autoload no
  172. set ethact eth1
  173. dhcp
  174. set serverip WWW.XXX.YYY.ZZZ
  175. tftpboot u-boot.bin
  176. The bridge also support (to a lesser extent) the localhost inderface, 'lo'.
  177. The 'lo' interface cannot use the RAW AF_PACKET API because the lo interface
  178. doesn't support Ethernet-level traffic. It is a higher-level interface that is
  179. expected only to be used at the AF_INET level of the API. As such, the most raw
  180. we can get on that interface is the RAW AF_INET API on UDP. This allows us to
  181. set the IP_HDRINCL option to include everything except the Ethernet header in
  182. the packets we send and receive.
  183. Because only UDP is supported, ICMP traffic will not work, so expect that ping
  184. commands will time out.
  185. The default device tree for sandbox includes an entry for lo on the sandbox
  186. host machine whose alias is "eth5". The following is an example of a network
  187. operation being tested on the lo interface.
  188. TFTP
  189. ....
  190. set ethact eth5
  191. tftpboot u-boot.bin
  192. SPI Emulation
  193. -------------
  194. Sandbox supports SPI and SPI flash emulation.
  195. This is controlled by the spi_sf argument, the format of which is:
  196. bus:cs:device:file
  197. bus - SPI bus number
  198. cs - SPI chip select number
  199. device - SPI device emulation name
  200. file - File on disk containing the data
  201. For example:
  202. dd if=/dev/zero of=spi.bin bs=1M count=4
  203. ./u-boot --spi_sf 0:0:M25P16:spi.bin
  204. With this setup you can issue SPI flash commands as normal:
  205. =>sf probe
  206. SF: Detected M25P16 with page size 64 KiB, total 2 MiB
  207. =>sf read 0 0 10000
  208. SF: 65536 bytes @ 0x0 Read: OK
  209. =>
  210. Since this is a full SPI emulation (rather than just flash), you can
  211. also use low-level SPI commands:
  212. =>sspi 0:0 32 9f
  213. FF202015
  214. This is issuing a READ_ID command and getting back 20 (ST Micro) part
  215. 0x2015 (the M25P16).
  216. Drivers are connected to a particular bus/cs using sandbox's state
  217. structure (see the 'spi' member). A set of operations must be provided
  218. for each driver.
  219. Configuration settings for the curious are:
  220. CONFIG_SANDBOX_SPI_MAX_BUS
  221. The maximum number of SPI buses supported by the driver (default 1).
  222. CONFIG_SANDBOX_SPI_MAX_CS
  223. The maximum number of chip selects supported by the driver
  224. (default 10).
  225. CONFIG_SPI_IDLE_VAL
  226. The idle value on the SPI bus
  227. Block Device Emulation
  228. ----------------------
  229. U-Boot can use raw disk images for block device emulation. To e.g. list
  230. the contents of the root directory on the second partion of the image
  231. "disk.raw", you can use the following commands:
  232. =>host bind 0 ./disk.raw
  233. =>ls host 0:2
  234. A disk image can be created using the following commands:
  235. $> truncate -s 1200M ./disk.raw
  236. $> echo -e "label: gpt\n,64M,U\n,,L" | /usr/sbin/sgdisk ./disk.raw
  237. $> lodev=`sudo losetup -P -f --show ./disk.raw`
  238. $> sudo mkfs.vfat -n EFI -v ${lodev}p1
  239. $> sudo mkfs.ext4 -L ROOT -v ${lodev}p2
  240. or utilize the device described in test/py/make_test_disk.py:
  241. #!/usr/bin/python
  242. import make_test_disk
  243. make_test_disk.makeDisk()
  244. Writing Sandbox Drivers
  245. -----------------------
  246. Generally you should put your driver in a file containing the word 'sandbox'
  247. and put it in the same directory as other drivers of its type. You can then
  248. implement the same hooks as the other drivers.
  249. To access U-Boot's emulated memory, use map_sysmem() as mentioned above.
  250. If your driver needs to store configuration or state (such as SPI flash
  251. contents or emulated chip registers), you can use the device tree as
  252. described above. Define handlers for this with the SANDBOX_STATE_IO macro.
  253. See arch/sandbox/include/asm/state.h for documentation. In short you provide
  254. a node name, compatible string and functions to read and write the state.
  255. Since writing the state can expand the device tree, you may need to use
  256. state_setprop() which does this automatically and avoids running out of
  257. space. See existing code for examples.
  258. Testing
  259. -------
  260. U-Boot sandbox can be used to run various tests, mostly in the test/
  261. directory. These include:
  262. command_ut
  263. - Unit tests for command parsing and handling
  264. compression
  265. - Unit tests for U-Boot's compression algorithms, useful for
  266. security checking. It supports gzip, bzip2, lzma and lzo.
  267. driver model
  268. - Run this pytest
  269. ./test/py/test.py --bd sandbox --build -k ut_dm -v
  270. image
  271. - Unit tests for images:
  272. test/image/test-imagetools.sh - multi-file images
  273. test/image/test-fit.py - FIT images
  274. tracing
  275. - test/trace/test-trace.sh tests the tracing system (see README.trace)
  276. verified boot
  277. - See test/vboot/vboot_test.sh for this
  278. If you change or enhance any of the above subsystems, you shold write or
  279. expand a test and include it with your patch series submission. Test
  280. coverage in U-Boot is limited, as we need to work to improve it.
  281. Note that many of these tests are implemented as commands which you can
  282. run natively on your board if desired (and enabled).
  283. It would be useful to have a central script to run all of these.
  284. --
  285. Simon Glass <sjg@chromium.org>
  286. Updated 22-Mar-14