原文出处:http://www.the-greathouses.net/blog/category/pcduino/ 该文章主要讲述使用串口连接pcduino,然后再启动时进入到U-BOOT,修改U-BOO环境参数以使板子挂载SD卡的分区作为文件系统,原文作者使用dosfstools来设置SD卡分区的文件系统类型,使用rsync拷贝系统文件,另外由于U-boot环境参数修改后无法保存,原文作者修改了u-boot-sunxi使其能在pcduino中使用,使用该修改过的u-boot-sunxi可导出导入保存在nand中的环境参数。另外原文作者没有说明分区问题,本人在试验的时候使用自带的fdisk工具对SD进行分区。
This evening I decided it was time to check out the boot loader and boot command options on the pcDuino. To access the serial port on the J5 debug port I used aSparkfun FTDI Basic Breakout-3.3v— a simple to use logic level serial to USB interface. With the power off and the FTDI Basic disconnected from the computer, I connected the serial lines and ground.
After double checking the connections, I plugged the FTDI Basic into my Windows laptop computer. After confirming the port assignment, I usedTeraTerm to open the serial port on my computer. The serial communication configuration needed to be set for 115200 Baud, 8-bit, No parity, 1 stop bit, no flow control, and the serial port assigned by Windows to the FTDI Basic.
After applying power to the pcDuino, the bootloader (U-Boot) startup sequence showed in the terminal window, followed by the familiar Linux boot messages as the kernel was loaded and Linux started. Surprisingly, at the end of the Linux boot, I was presented with aroot prompt. Instead of presenting a login prompt, the debug port goes directly to a root shell. This I will need to change!
Now for the real reason I wanted to try this. Access to U-Boot and the boot command line.
In the serial terminal window, I rebooted the pcDuino…
… and interrupted the U-Boot start up by pressing the space bar at the “Hit any key to stop autoboot” prompt.
Greeted by the U-Boot prompt. No to check for what commands are available for modifying the environment using thehelp command.
Current environment settings.
Interesting. By default, the A10 settins are loaded to memory from evb.bin and the kernel is loaded fromuImage from the NAND flash/boot partition. The default kernel command line sets/root to the NAND flash root partition. Then off it goes.
In Part 1 I described connecting to the pcDuino serial port and accessing the U-Boot subsystem. With this access to the boot environment, the task of booting to a root file system other than the NAND flash looked promising.
The pcDuino accepts a micro-SD card (I just refer to it as SD to save typing) for additional storage. It is best to partition and format the card with a Linux file system for use on the pcDuino.If you are attempting this, the following steps will result in a loss of all data already on an SD card.
For some of the steps below, additional software needed to be installed on the pcDuino. For formatting a DOS FAT partition, thedosfstools package must be installed. For copying the files between filesystems, I use thersync package.
First, the SD card must be inserted in the card slot and partitioned. By default, the pcDuino will attempt to automatically mount the SD card partitions, so these partitions must be unmounted after inserting the card. I’m lazy, so I just ask the system to unmount every thing accociated with the SD card slot. The redirection to /dev/null is to avoid error messages I would just ignore.
Next, the new partitions need defined. I set my card up with a small (16MB) FAT partition for future use as a/boot file system, and used the remaining space for the root file system. The pcDuino desktop DiskManager allows the formatting to be done from from a graphical interface. Or, as I prefer, the fdisk command line application can be used.
Once the partitions are created, the file systems need to be created, mounted, and a copy of the existing operating system copied to the corresponding locations. For my configuration, the following commands were used to accomplish this task.
With the new file systems on the card, I needed to make certain they were not automatically mounted.
Then, the file systems were copied. Starting with the /boot partition
And the root / file system
To test, I rebooted the system with the serial debug output connected to my lap top as I described inPart 1 and entered into the U-Boot command line. From the U-Boot prompt, I set the default root device to my root partition on the SD card and booted.
After booting, it was necessary to check if the root / was being used from the SD card.
CONFIRMED: The pcDuino will boot to an alternate root file system. All that’s needed now is to make it permanent.
Time to reboot the system and back into U-Boot to make the environment change permanent. Thesaveenv command is used to permanently write environment changes to non-volatile storage. In the case of the pcDuino the environment is saved to a specific NAND flash area.
No errors were displayed, and a check of the mounted file systems showed the SD card was being used for the root file system. Time for the critical test. Reboot without entering U-Boot to confirm the change is permanent.
FAILURE! The changes are not persistent. The saveenv did not work. No errors were displayed, but the environment was not updated.
After a detailed investigation, I concluded the saveenv was non-functional in the pcDuino U-Boot version. The NAND flash write routines are not present or operational. More details of the investigation into alternatives for controlling the boot process will be in Part 3 and a workable solution will be presented. Stay tuned!
In Part 1 and Part 2 of this series of posts I outlined the attempts I have made at using U-Boot to control the booting of the pcDuino. Specifically, I have been trying to configure the second stage boot to be from my SD card instead of the on board NAND flash. Unfortunately, the U-Boot implementation as installed does not allow persistent setting of the environment for boot from an alternative interface. And the installed U-Boot does not support the newerboot.scr oruEnv.txt extensions. The newer U-Boot versions available onlinux-sunxi are not compatible with the pcDuino. I also tried thefw_printenv andfw_setenv U-Boot tools, but they only work with /dev/mtdX NAND configurations. I was not able to find a ready made solution, so I had to roll my own.
The U-Boot environment is stored as simple list of strings in non-volatile memory with a 32-bit CRC added for validating the memory content. Typically, to modify the environment, a user will interrupt the boot process and access the U-Boot command line prompt. This can be made available on a serial port, or in some cases, on the main console. Once there is access to the U-Boot command line, it is only necessary to update the existing environment usingsetenv and then save the updates back to non-volatile memory using saveenv. For the pcDuino, the environment is stored in the NAND flash and should be updated with the new settings. The NAND flash update is not implemented. There are no error messages displayed, the environment is just not saved.
This led me to investigating where the environment is stored on the pcDuino. This was not hard to determine with a quick check of the pcDuino NAND file systems. The U-Boot environment is stored in the second NAND partition — /dev/nandb — as viewed from the Linux environment. Nothing special formatting is performed on the partition, it is treated as a raw data area, with the environment stored as 128K bytes of data starting at the beginning.
Now that I had the location of the environment, I thought should be able to use the default tools available with U-Boot to update this area. I proceeded to fetch the full source package for U-Boot from linux-sunxi and compiled the U-Boot tools without any problems. I then proceeded to try fw_printenv to confirm access to the environment.
That’s when my problems started with the tools. First, I had to create a fw_env.config file in the/etc directory. No problem, I just copied the sample and tried again. Next problem… no/dev/mtdX devices were found. That’s right. On the pcDuion, the NAND flash provides file system mapping via the/dev/nandX devices. Should be a simple matter of updating the/etc/fw_env.config file. Right? No. I updated the configuration, and tried again. This time I had a non-supportedioctl error output fromfw_printenv.
Time to look at the source code and find out how to make this work with the pcDuino. To make a long story short, the U-Boot supplied tools are centered around the/dev/mtd NAND flash implementation. It would not be a simple matter to update them in a compatible manner for supporting the pcDuino. My decision was to create my own tools specifically for the pcDuino.
After deciding I needed to write my own tools, I had a working prototype in less than 30 minutes. The most complicated portion of the code was calculating the CRC-32 and I was able to find existing code for that task. This was fine for me, but I knew there was additional interest in the pcDuino community. I added some error handling and default modes to the code and am making it available for general use.Read the warning at the end of this post!
Here are the files for setting your environment on the pcDuino. Extract to a directory on your pcDuino and follow the instructions in the include README.txt file. I am distributing as a source package that you will need to compile on your system. I am assuming that anyone who wants to try this does have some basic Linux skills.
Download the file from here: u-boot-pcduino-env.tgz
Quick instructions for downloading, installing, compiling and using from the command line.
After building the tools, you can run them from the build directory or install to /usr/local/bin using:
Refer to my previous posting (Part 2) for setting up an SD card partition for use as your root partition.
ONLY TRY THE ABOVE IF YOU UNDERSTAND WHAT YOU ARE DOING. Connecting to the serial debug port has the potential to damage your pcDuino if your connections are incorrect. Changes to the U-Boot environment can render your pcDuino unbootable. YOU HAVE BEEN WARNED!
手机版 | Archiver | 万博网页版登陆页派论坛 ( 粤ICP备15075382号-1 )