Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

  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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
.\"	$NetBSD: prep,v 1.24 2009/04/23 01:56:49 snj Exp $
.
There are two installation tools available.
The traditional miniroot
installer is script-based and may be netbooted or may be dumped to a disk
and run locally.
The ramdisk kernel with the
.Ic sysinst
installation utility is more flexible,
but can only be netbooted and has not been extensively tested.
.Pp
There are several possible installation configurations described in this
document.
Other configurations are possible, but less common.
If you are unable to install based on the information in this document,
post a message to
.Mt port-hp300@NetBSD.org
asking for help.
The configurations described in this document are as follows:
.Pp
.(bullet -compact
\*M netboots
.Li SYS_UBOOT
from a
.Nx
server running
.Xr rbootd 8 ,
or other server platforms (Linux, FreeBSD, SunOS, Solaris, HP-UX etc.) with
YAMAMORI Takenori's
.Li sun-rbootd
package and then runs the miniroot installation tools or a purely diskless
installation from a server on the same subnet (you must have root access).
For more information, refer to the NetBSD Diskless
HOW-TO at
.Lk http://www.NetBSD.org/docs/network/netboot/
and
.Lk http://www.NetBSD.org/docs/network/netboot/rbootd/
.Pp
.It
\*M loads
.Li SYS_UBOOT
from a local disk, tape, or floppy
and then runs the miniroot installation tools or a purely diskless
installation from a server as described above.
You will need
.Tn HP-UX
on your \*M if it does not have a SCSI interface or a floppy drive.
.Pp
.It
\*M loads
.Li SYS_INST
from a local disk.
You partition the drive
and then run the miniroot installation tools from that drive.
You will need
.Tn HP-UX
on your \*M if it does not have a SCSI interface.
.bullet)
The preferred method is to use another
.Nx
server to netboot the \*M client.
This procedure will not
work on the handful of models which are incapable of netbooting.
In particular, the 320, 350, 330, 318, and
319 might not have a recent enough BootROM.
The BootROM revision is printed when your workstation is first powered on
(or rebooted).
Revision B or later will definitely work.
BootROMs with numeric revisions such as 1.1 (on a 400s) will netboot
without any problems.
You can netboot from any built-in or add-on ethernet board on
a model with a supported BootROM.
.Pp
If you have access to a
.Nx*M
system, it is
.Em much
easier to simply upgrade than to install from scratch.
Skip down to the section on
.Sx Upgrading a previously-installed NetBSD System
.
.Ss2 Formatting your hard drives
.
.Nx*M
does not have the capability to perform a low-level format of hard
drives.
SCSI disks can be formatted on any platform with SCSI support and
then used on
.Nx*M .
HP-IB disks can only be formatted by the
.Tn HP-UX
.Xr mediainit 1
command.
You may need to first create the device nodes for your disk, as
.Tn HP-UX
was never very good about populating
.Pa /dev/rdsk
properly.
.(disp
.No # Ic "mknod /dev/dsk/IDs0 b 0 0xSCID00"
.No # Ic "mknod /dev/rdsk/IDs0 c 4 0xSCID00"
.No # Ic "mediainit -v /dev/rdsk/IDs0"
.disp)
.(item
.Em ID
is the HP-IB address (a.k.a. slave) of the disk in hexadecimal.
This is usually between
.Li 00
and
.Li 07 ,
but possibly up to
.Li 1F
(31 decimal) .
.item)
.(item
.Em SC
is the Select Code of the disk controller.
This is usually
.Li 07
for slow (i.e. built-in) HP-IB or
.Li 0E
(14 decimal) for SCSI or fast HP-IB.
.item)
.
.Ss2 Designing your disk's partition table
.
This step can sometimes be a real pain, especially when using
.Pa SYS_INST .
It's best to calculate it ahead of time.
.Pp
If you are installing to an HP-IB disk,
you will need information about your disk's geometry, based on 512-byte sectors.
The file
.Pa installation/misc/HP-IB.geometry
in the distribution has geometry information for
several HP-IB disks, but may be incomplete.
Geometry may be calculated from an HP-UX
.Pa /etc/disktab
entry, but note that HP-UX geometry is based
on 1024 byte sectors, while
.Nx Ns 's
is based on 512 byte sectors.
You should have all partitions start on cylinder boundaries.
.Pp
If you are installing to a SCSI disk, you don't need to worry about the
details of the geometry.
Just create a disklabel based on the total
number of sectors available on the disk.
.Pp
.Em A quick note about partitions:
Since the target disk will become the boot
disk for your new
.Nx*M
installation, you will need to treat the
.Sq Li a
and
.Sq Li c
partitions in a special manner.
Due to the size of the
.Nx*M
boot program (it spills into the area after the disklabel),
it is necessary to offset the beginning of the
.Sq Li a
partition.
For HP-IB disks, it is best to offset it by one cylinder from
the beginning of the disk.
For SCSI disks, just offset it by 100 KB (200 sectors).
Later, the
.Sq Li c
partition will be marked with the type
.Sq Li boot
and may not be used for a file system.
(For those unfamiliar
with historic
.Bx
partition conventions, the
.Sq Li c
partition is defined as the
.Sq entire disk ,
or the
.Sq raw partition . )
.Pp
.(Note
You will need at least a 6 MB swap partition (although 2-3*RAM is
recommended) if you are unable to netboot the installer, as the miniroot
is temporarily placed in this partition.
.Note)
.Pp
Here is an example disklabel from a 7959B HP-IB hard drive:
.(disp
# /dev/rrd0a:
type: HP-IB
disk: rd7959B
label:
flags:
bytes/sector: 512
sectors/track: 42
tracks/cylinder: 9
sectors/cylinder: 378
cylinders: 1572
total sectors: 594216
rpm: 3600
interleave: 1
trackskew: 0
cylinderskew: 0
headswitch: 0           # milliseconds
track-to-track seek: 0  # milliseconds
drivedata: 0

8 partitions:
#        size   offset    fstype   [fsize bsize   cpg]
  a:    37800      378    4.2BSD     1024  8192    16   #
  b:    66150    38178      swap     1024  8192    16   #
  c:   594216        0      boot                        # (Cyl.    0 - 1571)
  d:   489888   104328    4.2BSD     1024  8192    16   #
.disp)
.
.Ss2 Installing the bootstrap program locally
.
For earlier models incapable of netbooting, you need to install the
bootstrap program on a bootable local device, such as a hard disk, floppy
disk, or tape drive.
If you will be booting the miniroot over the
network, then you will be installing
.Pa installation/misc/SYS_UBOOT .
.Pp
If you do not have access to a netboot server to serve the miniroot
installer, you can use a primitive bootstrap program
.Pa installation/misc/SYS_INST
to load the miniroot from a locally attached device (such as a
disk, tape or CD-R).
This is not recommended, as
.Pa SYS_INST
is difficult to use, buggy, and provides no error checking when
partitioning your disk.
.Pp
If your system has SCSI, this is easy.
Just take a scratch SCSI disk (hard disk, zip disk, or CD-R)
and use any computer to dump the bootstrap program to it.
For example, to dump it to the
.Li sd1
disk on a non-i386 platform:
.(disp
.No # Ic "dd if=SYS_UBOOT of=/dev/sd1c"
.disp)
.Pp
If your system has a floppy drive, you can write the bootstrap program to
it using any computer with a floppy drive.
You will need to dump it using a utility like
.Ic rawrite
or
.Xr dd 1 .
Make sure to read back from the floppy to verify that the file has been
written correctly.
.Pp
If your system does not have SCSI or a floppy drive, you will need a
bootable operating system on your \*M so you can write files to the HP-IB
device.
You should probably write the bootstrap program to the disk you
will be installing
.Nx
onto.
.Pp
Using
.Tn HP-UX
to write to an HP-IB disk:
.(disp
.No # Ic "dd if=SYS_UBOOT of=/dev/rdsk/IDs0"
.disp)
.(item
.Em ID
is the HP-IB address (a.k.a. slave) of the disk in hexadecimal.
This is usually between
.Li 00
and
.Li 07 ,
but possibly up to
.Li 1F
(31 decimal) .
.item)
.Pp
Using
.Tn HP-UX
to write to an HP-IB tape:
.(disp
.No # Ic "dd if=SYS_UBOOT of=/dev/rmt/0mnb obs=20b conv=osync"
.disp)
.
.Ss2 Installing the miniroot file system locally
.
This step is only necessary if you are not loading the miniroot
installer from a netboot server.
Follow the same procedure for the bootstrap program, except use the
uncompressed miniroot file system
.No ( Pa installation/miniroot/miniroot.fs.gz No )
instead of the bootstrap program.
The only quirk is that you should place it at the offset of the swap
partition you calculated above in the disklabel.
In the example disklabel above, the offset is 38178 sectors of 512 bytes.
Therefore, the
.Xr dd 1
command would be something like:
.(disp
.No # Ic "gunzip miniroot.fs.gz"
.No # Ic "dd if=miniroot.fs of=/dev/rdsk/IDs0 seek=38178b"
.disp)
Note the
.Sq Li b
after the offset, which specifies blocks of 512 bytes.
.Pp
By dumping the miniroot to disk where the swap partition will be, you're
saving a step later where
.Pa SYS_INST
tries to download the miniroot over NFS.
Just make sure that when you enter the partition table into
.Pa SYS_INST
you use the same block offset for the swap partition as you dumped the
miniroot.
.
.Ss2 Configuring the netboot server
.
This step will configure your netboot server to provide
.Pa SYS_UBOOT
and the miniroot installer to your \*M.
.Pp
.so ../common/netboot
.
.Ss2 Put Series 400 systems in "HP-UX Compatible Boot Mode"
.
Series 400 systems can be configured to boot either
.Tn HP-UX
or
.Tn DomainOS .
To boot
.Nx*M
you must have your system configured in
.Sq Li "HP-UX Compatible Boot Mode" .
If, when you power on your machine, it does
.Em not
present a menu like the following, then you need to change your
configuration.
.(disp
Copyright 1990,
Hewlett-Packard Company.
All Rights Reserved.

BOOTROM  Series 400  Rev. 1.1
MD12 REV 1.2 1990/08/07.14:27:08
[...]
.disp)
.(enum
Attach a Domain keyboard or an HIL keyboard.
.br
The BootROM knows how to use either, even if
.Nx
doesn't yet.
.It
Put your system into
.Sq "service mode" .
.br
For a 4XXs, there's a toggle switch on the back of the machine (near the top).
For a 4XXt or 4XXdl, press the green button on the front, behind
the silly door.
For a 425e, there's a toggle switch on the back of the
machine (in the middle).
The second green LED should light up.
.It
Reset the machine.
.br
Press the reset button.
For a 4XXs, there's a small plunger on the back of
the machine (near the top).
For a 4XXt or 4XXdl, there's a white button
on the front, behind the silly door.
For a 425e, there's a button on the
back of the machine.
.It
Press
.Key RETURN
to get the Domain boot prompt
.No ( Li \*[Gt] No ) .
.br
You can type
.Key H
to get a list of available commands.
.It
Type the following sequence of commands to convert to
.Sq Li "HP-UX Compatible Boot Mode" .
.br
.(disp
.No "\*[Gt]" Ic "CF"
.No "Type [key] RETURN ?" Ic 2
.No "Type [key] RETURN ?" Ic 2
.No "Type T or P  RETURN ?" Ic P
.No "Type [key] RETURN ?" Ic E
.disp)
.It
Be sure to turn
.Sq "service mode"
.Em off
when you're done.
It may prevent you from selecting which device to boot from.
.enum)
See the FAQ for additional help.
.Lk http://www.NetBSD.org/ports/hp300/faq.html#domain
.
.Ss2 Searching for a bootable system
.
All the early hp300 Boot ROMs are very primitive and only allow a few
simple operations.
You can only interact with it after it is first powered on.
If you reboot the machine, it will ignore anything you type and
start loading the same OS you previously booted.
.Pp
At any time after it recognizes the keyboard, while it is doing its self
test or searching for a bootable system, you can hit reset to return it to
a cold-boot configuration.
On HIL keyboards, this is
.Key control-shift-break ,
where
.Key break
is the key in the upper left (where
escape is on sane keyboards).
There is no equivalent over serial terminal,
you'll need to power-cycle your machine.
.Pp
After it beeps (i.e. recognizes the HIL keyboard), press
.Key RETURN
twice to get the list of bootable devices.
.(disp
SEARCHING FOR A SYSTEM (RETURN To Pause)
.disp)
.Pp
The newer HP Boot ROM, present on Series 400 machines and some of the
later 300s (345, 375, 380, 382, 385) is capable of a little bit more.
To select which device to boot from, press
.Key RETURN
once after it beeps twice (i.e. recognizes the HIL keyboard) to get the
list of bootable devices.
.(disp
RESET To Power-Up, SPACE clears input   Select System, type RETURN       ?
.disp)
.Pp
The FAQ lists additional things you can do with the BootROM and describes
the order the BootROM looks for bootable devices.
.Lk http://www.NetBSD.org/ports/hp300/faq.html
.Pp
A normal power-on sequence (from a 400s) looks something like this:
.(disp
Copyright 1990,
Hewlett-Packard Company.
All Rights Reserved.

BOOTROM  Series 400  Rev. 1.1
MD12 REV 1.2 1990/08/07.14:27:08
MC68030 Processor
MC68882 Coprocessor
Configuration EEPROM
Utility Chip at 41
HP-HIL.Keyboard
 RESET To Power-Up
 Loading Memory
Self-Test Mode
 RESET To Power-Up, SPACE clears input
Select System, type RETURN
HP-IB
DMA-C0
 Self-Test Mode
RAM 33554158 Bytes
HP98644 (RS-232) at 9
HP PARALLEL at 12
HP98265 (SCSI S 32) at 14
HP98643 (LAN) at 21, AUI, 080009115DB3
Bit Mapped Video at 133 (Console)
 System Search Mode
                                        :RODIME RO3000T, 1406, 0
                                           1Z SYS_UBOOT
                                        :LAN080009115DB3, 2100, 0
                                           2Z SYS_UBOOT
                                        :HP7959, 702, 0, 0
                                           1H SYSHPUX
                                           1D SYSDEBUG
                                           1B SYSBCKUP
                                        :HP9122, 0700, 0, 0
                                           3Z SYS_INST
.disp)
.Pp
You should see your bootstrap program somewhere in this list.
If it's not here, then your \*M can't boot it and there's a problem somewhere.
To boot from a particular device, type in the two character name for it
and press
.Key RETURN .
In this example, you'd type
.Key 2Z
to boot from the network.
.
.Ss2 Selecting ethernet port on Series 400
.
Series 400 machines have two ethernet media types built into the
motherboard.
You may only use one at a time.
When your Series 400 workstation goes through the self-test when
powered on or rebooted, it will say one of the following:
.(disp
HP98643 (LAN) at 21, AUI
HP98643 (LAN) at 21, Thin
.disp)
.Pp
If the wrong type of network is selected, you will need to change the
ethernet port.
You will need to open the case (4XXt, 4XXdl, 4XXe) or
remove the motherboard (4XXs) to access the jumper.
Be sure to use static-prevention measures, as you could easily fry
your motherboard from carelessness.
If you are uncomfortable with this, ask a friend who is
aware of these issues.
There is a block of 8 jumpers at the rear of the
motherboard, labeled AUI/Thin.
You will need to put the jumpers in the
position necessary for your type of ethernet.
.
.Ss2 Running SYS_INST
.
This step is necessary
.Em only
if you cannot netboot.
.Pp
Chose
.Li SYS_INST
from the list of bootable devices that the BootROM found.
.Li SYS_INST
will load and prompt you for a command.
.Pp
.Em A quick note about disk numbers:
While in the
.Pa SYS_INST
program, you may use different unit numbers for the disks than when the
.Nx
kernel is running.
The unit number for a disk while in
.Pa SYS_INST
is calculated with the following formula:
.Pp
.(disp
unit = (controller * 8) + slaveID
.disp)
.Pp
Controllers are numbered 0, 1, ... starting with the lowest select code.
SCSI controllers and HP-IB controllers are counted separately.
Therefore,
if you had a system with an internal HP-IB interface at select code 7,
a fast HP-IB interface at select code 14, and a SCSI interface at select
code 16, unit numbers might be something like the following:
.Bl -column -offset indent HP-IB\ at\ 14,\ slaveID\ 5 Unit (disk:\ rd13)
.It Sy Location Ta Sy Unit
.It HP-IB\ at\ 7,\ slaveID\ 2 Ta 2 Ta (disk:\ rd2)
.It HP-IB\ at\ 14,\ slaveID\ 5 Ta 13 Ta (disk:\ rd13)
.It SCSI\ at\ 16,\ slaveID\ 0 Ta 0 Ta (disk:\ sd0)
.El
.Pp
You will need to place a disklabel on the disk.
.Pp
.(disp
.No "sys_inst\*[Gt]" Ic disklabel
.disp)
.(Note
It may be worth selecting the
.Sy zap
option initially to ensure that
the disklabel area is clear.
This may be especially important if an
HP-UX boot block had been previously installed on the disk.
.Note)
.Pp
Select the
.Sy edit
option, and answer the questions about your disk.
There may be several questions which you may not be sure of the answers to.
Listed below are guidelines for SCSI and HP-IB disks:
.Pp
.Bl -column -offset indent -compact Track-to-track?xx xxxxx
.It Bad\ sectoring? Ta NO
.It Ecc? Ta NO
.It Interleave? Ta 1
.It Trackskew? Ta 0
.It Cylinderskew? Ta 0
.It Headswitch? Ta 0
.It Track-to-track? Ta 0
.It Drivedata\ 0-4? Ta 0\ (for\ all\ Drivedata\ values)
.El
.Pp
Next, you will be asked to fill out the partition map.
You must provide responses for all 8 partitions.
Remember, you must have the sector offset for the
.Sq Li b
partition match the location you dumped the miniroot file system image.
Set the size and
offset of any unused partition to 0.
Note that sizes and offsets are expressed in
.Sq n sectors ,
assuming 512 byte sectors.
Care should be taken
to ensure that partitions begin and end on cylinder boundaries (i.e. size
and offset is an even multiple of the number of sectors per cylinder).
While this is not technically necessary, it is generally encouraged.
.Pp
.(Note
When setting the partition type of the
.Sq Li b
partition, make sure to
specify it as an
.Li ffs
partition so that the miniroot can be mounted (even
if this will be a swap partition).
You will be given a chance to clean
this up later in the installation process.
.Note)
.Pp
Once you have edited the label, select the
.Sy show
option to verify that it is correct.
If so, select
.Sy write
and
.Sy done .
Otherwise, you may re-edit the label.
.Pp
In an earlier step, we already copied the miniroot image to the target
disk.
.Pp
Boot from the miniroot file system.
.Pp
.(disp
.No "sys_inst\*[Gt]" Ic boot
.disp)
.Pp
Enter the disk from which to boot.
The kernel in the miniroot file system will be booted into single-user mode.
.
.Ss2 Choosing a kernel location
.
Once the bootstrap program
.Li SYS_UBOOT
has started, it will pause and let you chose a kernel location, name, and
options:
.(disp
\*[Gt]\*[Gt] NetBSD/hp300 Primary Boot, Revision 1.13
\*[Gt]\*[Gt] (gregm@mcgarry, Mon Apr 15 08:46:32 NZST 2002)
\*[Gt]\*[Gt] HP 9000/425e SPU
\*[Gt]\*[Gt] Enter "reset" to reset system.
Boot: [[[le0a:]netbsd][-a][-c][-d][-s][-v][-q]] :-
.disp)
.Pp
If your kernel is on a different device than
.Li SYS_UBOOT
then you will need to type in where to find it.
This is the case, for
example, if your model is incapable of netbooting and you started
.Li SYS_UBOOT
from a floppy, and the miniroot installer is on a netboot server.
In this case, you'd type in
.Sq Li le0
at the prompt.
.Pp
If you've installed the miniroot on your disk, you can always boot from
that by using partition
.Sq Li b
when prompted by
.Li SYS_UBOOT .
For example, to boot the miniroot from an HP-IB disk on controller 0 at
slave ID 2, you'd type:
.(disp
.No "Boot: [[[rd0a:]netbsd][-a][-c][-d][-s][-v][-q]] :- " Ic "rd2b:netbsd"
.disp)