forked from jdkoftinoff/mb-linux-msli
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
138 lines (86 loc) · 4.04 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
uClinux distribution for MicroBlaze.
====================================
Initially configured for Meyer Sound D-Mitri I/O and DGPIO modules.
Kernel 2.6.30 (modifications by Petalogix and Meyer Sound).
uClibc 0.9.30.1 (modifications by Meyer Sound).
Directory structure:
====================
The build environment should contain the following directories:
mb_gnu (from mb-gcc4-msli repository) is a gcc4 toolchain (from
git.xilinx.com, patched to compile on modern Linux distributions).
microblaze-toolchain-sources (from mb-gcc3-msli repository) is a gcc3
toolchain (from Petalogix sources, patched to compile on modern Linux
distributions).
* mbbl-mkbootimage (from mbbl repository) is the boot image maker.
* dtc is Jon Loeliger's device tree compiler (same as the one supplied
with the kernel).
* mcsbin is a binary <-> MCS converter similar to Xilinx promgen.
* uClinux-dist is current uClinux, except:
1. uClinux-dist/uClibc is updated to uClibc 0.9.30.1 with Microblaze
support (current uClibc release with local patches),
2. uClinux-dist/linux-2.6.x is based on
git://developer.petalogix.com/linux-2.6-microblaze.git + local
patches,
3. build procedure is updated to accommodate those changes and by
default produce a kernel + directory tree for Meyer Sound D-Mitri
I/O and DGPIO modules.
* local contains the device tree and script for building the image
from compiled kernel and filesystem tree.
buildtools.sh is a script that builds all of the above.
This initial version builds a non-MMU kernel and userspace.
Build procedure:
================
To build the toolchain:
./buildtools.sh
To add the compilers' directories to the path:
. prepare.sh
To build the kernel and filesystem tree:
cd uClinux-dist
make config
make
To prepare the boot image:
cd ../local
./makeimage.sh
Installation procedure:
=======================
To load Linux on D-Mitri:
NEW FLASH INSTALLATION PROCEDURE:
Build a bitstream and software in XPS, initialize BRAM in bitstream
with mbbl binary (you may have to change the paths in the files,
currently /home/alexb is still hardcoded in some of them). Use iMPACT
to flash two MCS files -- download.mcs generated by Xilinx tools
(promgen or interactive prom file formatter in iMPACT) from
download.bit bitstream file, and bootimage.mcs located in "local"
directory, generated by Linux image build procedure.
Use a terminal connected to the serial port (115200, 8N1) to monitor the boot progress and log in at the console.
FLASH UPDATE PROCEDURE:
Convert download.mcs file into raw binary:
../mcsbin/mcsbin -b -y download.mcs download.bin
Upload bootimage.bin and download.bin to /tmp using ftp or lrz (zmodem).
On FPGA (over telnet or serial console) run:
flashw -u -f /tmp/download.bin /dev/mtd0
flashw -u -o 3145728 -f /tmp/bootimage.bin /dev/mtd0
Power-cycle the device.
OLD/DEBUGGING PROCEDURE:
Build a bitstream and software in XPS, initialize BRAM in bitstream
with mbbl binary (you may have to change the paths in the files,
currently /home/alexb is still hardcoded in some of them).
Program flash or FPGA with the bitstream, have a terminal connected to
the serial port (115200, 8N1), confirm that mbbl started and given the
error message about missing kernel or device tree. If mbbl is loading
an old kernel that is already in flash, press Ctrl-C twice while it's
loading.
Run XMD, wait for error message, stop the processor, record the stop
address, load:
local/dt.dtb at 0x90800000
continue from the stop address, after another error message stop the
processor, record the stop address, load:
uClinux-dist/linux-2.6.x/arch/microblaze/boot/linux.bin at 0x90000000
local/romfs.bin.gz at 0x97c00000
Continue from the stop address. Linux will boot from those images.
Once Linux is booted, log in at the serial console, upload bootimage.bin
to /tmp using ftp or lrz (zmodem).
On FPGA (over telnet or serial console) run:
flashw -u -o 3145728 -f /tmp/bootimage.bin /dev/mtd0
Reset and re-program FPGA or power-cycle the device (if FPGA bitstream
is already programmed in flash) -- Linux will boot from the images in flash.