メッセージ欄

分類 【NetBSD】 で検索

一覧で表示する

NetBSD/evbarm (APC8750) 2013/8/16
2013/08/16(金) 26:53 NetBSD はてブ情報 はてブに登録 はてブ数

少しだけ進みました。
NetBSD/evbarm (APC) booting ...
[ Kernel symbol table missing! ]
Loaded initial symtab at 0xc01b4364, strtab at 0xc01d3494, # entries 7940
pmap_postinit: Allocated 35 static L1 descriptor tables
Copyright (c) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
    2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013
    The NetBSD Foundation, Inc.  All rights reserved.
Copyright (c) 1982, 1986, 1989, 1991, 1993
    The Regents of the University of California.  All rights reserved.

NetBSD 6.99.23 (APC) #16: Fri Aug 16 16:42:14 UTC 2013
        root@builder.localdomain:/usr/obj/sys/arch/evbarm/compile/APC
total memory = 512 MB
avail memory = 499 MB
mainbus0 (root)
cpu0 at mainbus0 core 0: ARM1176JZ-S r0p7 (ARM11J V6ZK core)
cpu0: DC enabled IC enabled WB enabled LABT
cpu0: 16KB/32B 4-way L1 Instruction cache
cpu0: 16KB/32B 4-way write-back-locking-C L1 Data cache
vfp0 at cpu0: VFP11
obio0 at mainbus0
wmicu0 at obio0 addr 0xd8140000-0xd814ffff
com0 at obio0 addr 0xd8200000-0xd820ffff intr 322: ns8250 or ns16450, no fifo
com0: console
wmtmr0 at obio0 addr 0xd8100000-0xd810ffff intr 48: VC System Timer
rn_init: radix functions require max_keylen be set
boot device: <unknown>
root device:
えらい苦労して、割り込みコントローラ(wmicu)をシリアル(com)の前にアタッチさせて、表示上はうまく動いているように見えますが、肝心のシリアルで入力ができないです。

昨日からの変更点をつらつらまとめておきます。

comがxintを使っていたのをintrに変えました。xintをIRQと勘違いしていました。sizeも指定が必要で64kB (0x10000) を使っています。intrは32です。サイズ指定に伴い、bus_space_mapの第三引数を8の即値からoba->oba_sizeに変更しました。

addrに仮想アドレスを指定していたものを物理アドレスに変更しました。昨日の、Fatal kernel mode data abortのエラーは、これで収まりました。いい加減な話ですが、エラーメッセージで検索すると、物理・仮想アドレス周りが怪しいということで。

これ以外にもdata abort関連のエラーに遭遇しました。大げさなエラーですが、たいていはゼロで割ったり、NULLを参照したり、自分で書いたプログラムが大抵バグを引き起こしていました。多くは、コンパイルを通すためにコメントアウトしたり、中身を見ないで適当な辻褄合わせをしたところでした。結局は負債となって、自分に帰ってくるだけですね。

obioはcomよりもwmicuを先にattachさせるために、obio_attach_criticalという関数を一つ書きました。そこでconfig_foundを呼ぶことでwmicuを先に呼び出します。kern/subr_autoconf.cの中をさまよって、結局のところXXX_matchが呼ばれた時の戻り値の大きいものをattachするということがわかったので、wm8750_intr.cのmatchの戻り値を(とりあえず)10にしておきました。

obio_attach_criticalの方法は、@nonakapさんからxscale/pxa2x0.cでも同様のことをやっていることを教えてもらい、それを真似したものです。とはいえ、なんとなく強引な気もします。きっと、attachの順序のルールを読み解けば、なんとかなるんじゃないかと思って、あれこれやってみたのですが、結局はダメでした。たとえば、デバイス名のアルファベット順にattachするのでは、などと思いましたが、まったく関係がありません。完全には追えていませんが、files.XXXXのインクルードされた順、というのが現時点での「だいたいあってる」回答のようです。実際には、configされた時点で決まるようで、自動生成されるevbarm/compile/obj/APC/ioconf.cの記述が手掛かりのようです。ちなみに、これを手で直すのはやめといたほうがよいそうです。このあたりは、@cvsyncさんにもアドバイスをいただきました。

wmtmrはコンパイルを通すために削除していたbus_space_mapを復活させました。ちなみに、comが先にattachされている時代に、wm8750_tmr.cのdelayが呼ばれて落ちるという事象がありました。delayの中でscのNULLチェックに引っかかってpanicしていました。attachされる前なので当然です。仕方がないので、NULLであれば黙ってreturnするという処理でごまかしました。matchの戻り値でコントロールすれば、このごまかし処理も不要になりそうですね。

wmintrもwmtmrと同様にbus_space_mapを復活させました。ぐらいかな。matchの戻り値の増加は先の説明のとおりです。実は、割り込みコントローラが2個あるのですが、二つ目のコントローラ分はサボっています。そもそも、ちゃんと動いているのかわからないし。

com, obioをevbarm/apcからarm/wmtに移しました。com, obioはもともとevbarm/hdl_gからコピーしてきたものなのでevbarm/apcにありましたが、WM8750的にはオンボードということでarm/wmtがいいかなぁということで。

全体的に、モグラたたきをしながらボチボチ進めている感じです。
シリアルがちゃんと動くようになれば、mdで/sbin/initぐらいまで行けたりしますかね。シリアルは、入力だけでなく出力も遅すぎなので、いろいろ足りてない感じなんでしょうね。

NetBSD/evbarm (APC8750)
2013/08/15(木) 28:59 NetBSD はてブ情報 はてブに登録 はてブ数

ここまで進んだー。
わーい。Raspberry PIをベースにしています。

モノはこれです。
http://apc.io/products/8750a/
WMT # set serverip 192.168.0.10
WMT # tftpboot 8000 netbsd.bin
EEP-less strapping = TRUE
TFTP from server 192.168.0.10; our IP address is 192.168.0.2
Filename 'netbsd.bin'.
Load address: 0x8000
Loading: #################################################################
         #################################################################
         #######################################T ##########################
         #################################################################
         #################################################################
         #################################################################
         #################################################################
         ######################################
done
Bytes transferred = 2520256 (2674c0 hex)
WMT # go 8000
## Starting application at 0x00008000 ...
00008328
NetBSD
00000000 00000000 0048096b 00000412
00000000 00000412 00000004 00000412
c0000000 00000000 0048096b 0000041e
00003000 0000041e 00000004 0000041e
fe000000 d8000000 010fffff 00000412
00003f80 d8000412 00000010 00000412
00000000 00000000 00000000 00000000
00000000 00000000 00000000 00000000

NetBSD/evbarm (APC) booting ...
initarm: Configuring system ...
arm32_bootmem_init: memstart=0, memsize=0x20000000, kernelstart=0x8000
arm32_bootmem_init: kernelend=0x281000
arm32_bootmem_init: adding 130431 free pages: [0x281000..0x1fffffff] (VA 0xc0281000)
arm32_bootmem_init: adding 8 free pages: [0..0x7fff] (VA 0xc0000000)
arm32_kernel_vm_init: 1 L2 pages are needed to map 0x2ac000 kernel bytes
arm32_kernel_vm_init: allocating page tables for vectoradd_pages: adding pv 0xc026fbe8 (pa 0x281000, va 0xc0281000, 1 pages) at tail
 kerneladd_pages: appending pv 0xc026fe70 (0x282000..0x282fff) to 0x281000..0x281fff
 vmadd_pages: appending pv 0xc026fe84 (0x283000..0x283fff) to 0x281000..0x282fff
add_pages: appending pv 0xc027892c (0x284000..0x287fff) to 0x281000..0x283fff
add_pages: appending pv 0xc026fe98 (0x288000..0x288fff) to 0x281000..0x287fff
add_pages: appending pv 0xc026feac (0x289000..0x289fff) to 0x281000..0x288fff
add_pages: appending pv 0xc026fec0 (0x28a000..0x28afff) to 0x281000..0x289fff
add_pages: appending pv 0xc026fed4 (0x28b000..0x28bfff) to 0x281000..0x28afff
add_pages: appending pv 0xc026fee8 (0x28c000..0x28cfff) to 0x281000..0x28bfff
add_pages: appending pv 0xc026fefc (0x28d000..0x28dfff) to 0x281000..0x28cfff
add_pages: appending pv 0xc026ff10 (0x28e000..0x28efff) to 0x281000..0x28dfff
add_pages: appending pv 0xc027016c (0x28f000..0x28ffff) to 0x281000..0x28efff
add_pages: appending pv 0xc0270180 (0x290000..0x290fff) to 0x281000..0x28ffff
add_pages: appending pv 0xc0270194 (0x291000..0x291fff) to 0x281000..0x290fff
add_pages: appending pv 0xc02701a8 (0x292000..0x292fff) to 0x281000..0x291fff
add_pages: appending pv 0xc02701bc (0x293000..0x294fff) to 0x281000..0x292fff
add_pages: appending pv 0xc0270158 (0x295000..0x296fff) to 0x281000..0x294fff
add_pages: appending pv 0xc026fc64 (0x297000..0x29afff) to 0x281000..0x296fff
Creating L1 page table at 0x00284000
arm32_kernel_vm_init: adding L2 pt (VA 0xc0281000, PA 0x281000) for VA 0xffff0000
 (vectors)arm32_kernel_vm_init: adding L2 pt (VA 0xc0282000, PA 0x282000) for VA 0xc0000000 (kernel)
arm32_kernel_vm_init: adding L2 pt (VA 0xc0283000, PA 0x283000) for VA 0xc1000000 (vm)
arm32_kernel_vm_init: adding L2 pt (VA 0xc0288000, PA 0x288000) for VA 0xc1400000 (vm)
arm32_kernel_vm_init: adding L2 pt (VA 0xc0289000, PA 0x289000) for VA 0xc1800000 (vm)
arm32_kernel_vm_init: adding L2 pt (VA 0xc028a000, PA 0x28a000) for VA 0xc1c00000 (vm)
arm32_kernel_vm_init: adding L2 pt (VA 0xc028b000, PA 0x28b000) for VA 0xc2000000 (vm)
arm32_kernel_vm_init: adding L2 pt (VA 0xc028c000, PA 0x28c000) for VA 0xc2400000 (vm)
arm32_kernel_vm_init: adding L2 pt (VA 0xc028d000, PA 0x28d000) for VA 0xc2800000 (vm)
arm32_kernel_vm_init: adding L2 pt (VA 0xc028e000, PA 0x28e000) for VA 0xc2c00000 (vm)
Mapping kernel
arm32_kernel_vm_init: adding chunk for kernel text 0x8000..0x1affff (VA 0xc0008000)
add_pages: adding pv 0xc026fbd4 (pa 0x8000, va 0xc0008000, 424 pages) before pa 0x281000
arm32_kernel_vm_init: adding chunk for kernel data/bss 0x1b0000..0x280fff (VA 0xc01b0000)
add_pages: appending pv 0xc026fc3c (0x1b0000..0x280fff) to 0x8000..0x1affff
add_pages: merging pv 0xc026fbe8 (0x281000..0x29afff) to 0x8000..0x280fff
Listing Chunks
arm32_kernel_vm_init: pv 0xc026fbd4: chunk VA 0xc0008000..0xc029afff (PA 0x8000, prot 3, cache 1)

Mapping Chunks
arm32_kernel_vm_init: mapping last chunk VA 0xc0008000..0xc029afff (PA 0x8000, prot 3, cache 1)
pmap_map_chunk: pa=0x8000 va=0xc0008000 size=0x293000 resid=0x293000 prot=0x3 cache=1
PPPPPPPPLLLLLLLLLLLLLLLSLLLLLLLLLPPPPPPPPPPP
devmap: d8000000 -> d8ffffff @ fe000000
pmap_map_chunk: pa=0xd8000000 va=0xfe000000 size=0x1000000 resid=0x1000000 prot=0x3 cache=0
SSSSSSSSSSSSSSSS
                             Physical              Virtual        Num
                       Starting    Ending    Starting    Ending   Pages
               SDRAM: 0x00000000 0x1fffffff 0xc0000000 0xdfffffff 131072
        text section: 0x00008000 0x001affff 0xc0008000 0xc01affff 424
        data section: 0x001b0000 0x0026f4c0 0xc01b0000 0xc026f4c0 192
         bss section: 0x0026f4c0 0x0028096c 0xc026f4c0 0xc028096c 18
   L1 page directory: 0x00284000 0x00287fff 0xc0284000 0xc0287fff 4
   ABT stack (CPU 0): 0x0028f000 0x0028ffff 0xc028f000 0xc028ffff 1
   FIQ stack (CPU 0): 0x00290000 0x00290fff 0xc0290000 0xc0290fff 1
   IRQ stack (CPU 0): 0x00291000 0x00291fff 0xc0291000 0xc0291fff 1
   UND stack (CPU 0): 0x00292000 0x00292fff 0xc0292000 0xc0292fff 1
  IDLE stack (CPU 0): 0x00293000 0x00294fff 0xc0293000 0xc0294fff 2
           SVC stack: 0x00295000 0x00296fff 0xc0295000 0xc0296fff 2
      Message Buffer: 0x00297000 0x0029afff 0xc0297000 0xc029afff 4
   Exception Vectors: 0x0029b000 0x0029bfff 0xffff0000 0xffff0fff 1
         Free Memory: 0x0029c000 0x1fffffff                       130404
         Free Memory: 0x00000000 0x00007fff                       8
switching to new L1 page table @0x284000...TTBR0=0x284000 OK
done.
nfreeblocks = 2, free_pages = 130412 (0x1fd6c)
bootstrap done.
vectors 0xffff0000
init subsystems: stacks vectors undefined page pmap_physload pmap [ Kernel symbol table missing! ]
done.
Loaded initial symtab at 0xc01b4390, strtab at 0xc01d34f0, # entries 7943
pmap_postinit: Allocated 35 static L1 descriptor tables
Copyright (c) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
    2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013
    The NetBSD Foundation, Inc.  All rights reserved.
Copyright (c) 1982, 1986, 1989, 1991, 1993
    The Regents of the University of California.  All rights reserved.

NetBSD 6.99.23 (APC) #8: Thu Aug 15 19:47:45 UTC 2013
        root@builder.localdomain:/usr/obj/sys/arch/evbarm/compile/APC
total memory = 512 MB
avail memory = 499 MB
mainbus0 (root)
cpu0 at mainbus0 core 0: ARM1176JZ-S r0p7 (ARM11J V6ZK core)
cpu0: DC enabled IC enabled WB enabled LABT
cpu0: 16KB/32B 4-way L1 Instruction cache
cpu0: 16KB/32B 4-way write-back-locking-C L1 Data cache
vfp0 at cpu0: VFP11
obio0 at mainbus0
com0 at obio0 addr 0xfe200000 xint -1071199468data_abort_handler: data_aborts fsr=0x1808 far=0xca070000
Fatal kernel mode data abort: 'External Non-Linefetch Abort (S)'
trapframe: 0xc0296d00
FSR=00001808, FAR=ca070000, spsr=800001d3
r0 =00000000, r1 =ca070000, r2 =00000001, r3 =00000000
r4 =c1a55d88, r5 =c02702fc, r6 =c0296d5b, r7 =c01b16dc
r8 =c018c70c, r9 =c0180f38, r10=00000000, r11=c0296d7c
r12=c000f0d4, ssp=c0296d50, slr=c001297c, pc =c000f0d4

Stopped in pid 0.1 (system) at  netbsd:generic_bs_w_1:  strb    r3, [r1, r2]
db>

BeagleBone Black でNetBSD
2013/05/14(火) 24:16 NetBSD はてブ情報 はてブに登録 はてブ数

BeagleBone Blackを買いました。

http://beagleboard.org/Products/BeagleBone%20Black

シリアルは秋月のFDTI USBシリアルケーブル(3.3V) がぴったりです。
電源はminiUSBで給電して動作しました。

20130514_235422~01.jpg

スペック概要は次の表のとおりです。
CPUAM3359 ARM Cortex-A8 1GHz
Memory 2GB on-board storage using eMMC, 512MB DDR3 (800MHz x 16), microSD card slot
USBHS USB 2.0 Client Port, LS/FS/HS USB 2.0 Host Port
VideomicroHDMI, cape add-ons
AudiomicroHDMI, cape add-ons
Supported Interfaces4x UART, 8x PWM, LCD, GPMC, MMC1, 2x SPI, 2x I2C, A/D Converter, 2xCAN Bus, 4 Timers
購入したのはTechShareで、価格は5,460円 (送料210円) でした。5/11に注文して5/13に到着だったので思った以上に早く到着しました。

NetBSDを動かすわけですが、前のモデルのBeagleBoneのkernelがあるので、それを起動させてみることにしました。

シリアルをつないで起動するとU-bootが起動します。

素早く、enterを押してU-bootのプロンプトに。

FATでフォーマットしたmicroSDにnetbsd.binをロードして、起動します。
U-Boot# fatload mmc 0 80300000 netbsd.bin
reading netbsd.bin
2997696 bytes read in 346 ms (8.3 MiB/s)
U-Boot# go 80300000
## Starting application at 0x80300000 ...
deghuboot arg = 0x1, 0x9fe4368c, 0x9fe4368c, 0x80300000
sdram_config = 0x61c05332
[ Kernel symbol table missing! ]
Loaded initial symtab at 0x80554d78, strtab at 0x8057c198, # entries 10034
pmap_postinit: Allocated 35 static L1 descriptor tables
Copyright (c) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
    2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013
    The NetBSD Foundation, Inc.  All rights reserved.
Copyright (c) 1982, 1986, 1989, 1991, 1993
    The Regents of the University of California.  All rights reserved.

NetBSD 6.99.19 (BEAGLEBONE) #0: Sat May 11 00:21:12 UTC 2013
        builds@b6.netbsd.org:/home/builds/ab/HEAD/evbarm/201305102100Z-obj/home/builds/ab/HEAD/src/sys/arch/evbarm/compile/BEAGLEBONE
total memory = 512 MB
avail memory = 498 MB
cprng kernel: WARNING insufficient entropy at creation.
mainbus0 (root)
cpu0 at mainbus0 core 0: 550 MHz Cortex-A8 r3p2 (Cortex V7A core)
cpu0: DC enabled IC enabled WB disabled EABT branch prediction enabled
cpu0: 32KB/64B 4-way L1 Instruction cache
cpu0: 32KB/64B 4-way write-back-locking-C L1 Data cache
cpu0: 256KB/64B 8-way write-through L2 Unified cache
vfp0 at cpu0: NEON MPE (VFP 3.0+)
obio0 at mainbus0 base 0x44000000-0x4fffffff: On-Board IO
omapicu0 at obio0 addr 0x48200000-0x48200fff intrbase 0
prcm0 at obio0 addr 0x44e00000-0x44e01fff: Power, Reset and Clock Management
sitaracm0 at obio0 addr 0x44e10000-0x44e11fff: control module, rev 1.0
gpmc0 at mainbus0 base 0x50000000: General Purpose Memory Controller, rev 6.0
gpmc0: CS#0 valid, addr 0x08000000, size 256MB
com0 at obio0 addr 0x44e09000-0x44e09fff intr 72: ns16550a, working fifo
com0: console
sdhc0 at obio0 addr 0x48060100-0x48060fff intr 64: SDHC controller
sdhc0: SD Host Specification 2.0, rev.49
sdmmc0 at sdhc0 slot 0
sdhc1 at obio0 addr 0x481d8100-0x481d8fff intr 28: SDHC controller
sdhc1: SD Host Specification 2.0, rev.49
sdmmc1 at sdhc1 slot 0
tiiic0 at obio0 addr 0x44e0b000-0x44e0bfff intr 70: rev 0.11
iic0 at tiiic0: I2C bus
seeprom0 at iic0 addr 0x50: AT24Cxx EEPROM: size 32768
tps65217pmic0 at iic0 addr 0x24: TPS65217C Power Management Multi-Channel IC (rev 1.2)
tps65217pmic0: power sources [USB] max 300 mA, AC max 2500 mA
tps65217pmic0: [LDO1: 1800 mV] [LDO2: 3300 mV] [LDO3: 1800 mV] [LDO4: 3300 mV] [DCDC1: 1500 mV] [DCDC2: 1100 mV] [DCDC3: 1100 mV]
omapdmtimer0 at obio0 addr 0x48040000-0x48040fff intr 68: DMTIMER2
omapdmtimer1 at obio0 addr 0x44e31000-0x44e31fff intr 67: DMTIMER1ms
omapdmtimer2 at obio0 addr 0x48044000-0x48044fff intr 92: DMTIMER4
omapwdt32k0 at obio0 addr 0x44e35000-0x44e35fff: rev 0.1
cpsw0 at obio0 addr 0x4a100000-0x4a107fff intrbase 40: TI CPSW Ethernet
cpsw0: Ethernet address XX:XX:XX:XX:XX:XX
ukphy0 at cpsw0 phy 2WARNING: module error: vfs load failed for `miiverbose', error 45
: OUI 0x00800f, model 0x000f, rev. 1
ukphy0: 10baseT, 10baseT-FDX, 100baseTX, 100baseTX-FDX, auto
ld0 at sdmmc1: <0xfe:0x014e:MMC02G:0x00:0x48168605:0x000>
ld0: 1832 MB, 930 cyl, 64 head, 63 sec, 512 bytes/sect x 3751936 sectors
ld0: 4-bit width, bus clock 52.000 MHz
ld1 at sdmmc0: <0x03:0x5344:SU16G:0x80:0x6161a51b:0x0b6>
ld1: 15193 MB, 7717 cyl, 64 head, 63 sec, 512 bytes/sect x 31116288 sectors
ld1: 4-bit width, bus clock 25.000 MHz
cprng sysctl: WARNING insufficient entropy at creation.
boot device: <unknown>
root device:
root deviceを聞くところまであっさりと起動しましたね。

microSDにファイルシステムを作ってあげれば、さらに先に進めそうな気がしますね。

USL-5Pとudlとwsconsとttys
2013/01/05(土) 16:38 NetBSD はてブ情報 はてブに登録 はてブ数

せっかくインストールしたUSL-5Pもシリアルやssh経由だけで使うのも何とも味気ないものですから、豊富なUSBポートを活用してディスプレイとキーボードをつないでみましょう。

ディスプレイはCentury LCD-8000U, キーボードはELECOM TK-UP84CPWHです。

もちろんX Window Systemを動かすのが見た目のインパクトも大きいのですが、kernelにもXにもパッチが必要で割と手間がかかります。ということで、まずはコンソールだけでもやってみようと思ったのであります。

2012年3月にもコンソールに挑戦して敗北していることもあって、いっちょう今回は逃げずに頑張ってみましょうと。

結論から言うと動きました。

pg92onUSL5P.jpg

landiskに関してはkernelに
options         WSEMUL_VT100            # VT100 / VT220 emulation
を定義して作り直す必要がありました。これをつけないと
wsconscfg: WSDISPLAYIO_ADDSCREEN: Device not configured
というエラーメッセージが出てしまいます。実は、これはwscons.confの
screen  1       -       vt100
に書かれているvt100をみて、wsconsが「vt100のエミュレーションないなー、デバイスコンフィグできませんなー」ということのようですね。

wsconscfgコマンドを使うとわかるのですが、
usl5p# wsconscfg -e dumb 1
usl5p# wsconscfg -e vt100 1
てな具合で、知っている端末エミュレーションだとエラーを出さずに成功し、
usl5p# wsconscfg -e sun 1
wsconscfg: WSDISPLAYIO_ADDSCREEN: Device not configured
てな具合で、知らない端末エミュレーションだと上のようなエラーを出すようです。知らない端末だと教えてくれるといいんですけど、wsdisplay.c#364あたりからすると、return ENXIO つまりDevice not configuredを返しているので、そこまでハンドリングできないようです。

そしてなぜか、screen 2, screen 3を作ろうとすると、メモリをアロケートできませんというエラーが出ます。
options        WSDISPLAY_DEFAULTSCREENS=4
をカーネルのコンフィグに足してみましたが、状況変わらず。これについてはちょっとあきらめることにしました。

先のwscons.confで作ったscreenに対応するttyがttysに書かれた/dev/ttyE1になるようですね。
ttyE1   "/usr/libexec/getty Pc"         vt220   on secure
よくわかっていないのですが、console = screen 0 = ttyE0と考えておけばよいのかなぁ。そいでもって、screen 1 = ttyE1で有効にしてやれば動くと。

/etc/ttyactionにもこういうの書いてあるし。ttyE0とconsoleは深い関係にありそうですなー。この辺の整合性が取れていないとconsoleでもrootでログインできなくなっちゃったりするんでしょうね。
ttyE0   *       chown ${USER}:tty /dev/console
と思ったらNetBSD/landiskにはなかったな。うーん。

さて、wsconsですが、黒字に白文字というのはいかにもパッとしません。
きっと色ぐらいは変えられるだろうと思い、wsconsctlなどといういかにもなコマンドを発見し、おー、オプションに-aを渡せば設定項目が全部表示されるんだねー。と思い。
usl5p# wsconsctl -a
type=usb
bell.pitch=1500
bell.period=100
bell.volume=50
bell.pitch.default=1500
bell.period.default=100
bell.volume.default=50
wsconsctl: "map" not shown with -a; use "wsconsctl map" to view.
repeat.del1=400
repeat.deln=100
repeat.del1.default=400
repeat.deln.default=100
ledstate=0
encoding=us
keyclick=0
scroll.mode=0
scroll.modifier=1
あれぇ? 色に関する項目がないですねぇ。
どうやら、オプションに-dを与えないとディスプレイ関連の設定値は出てこないんですね。
usl5p# wsconsctl -f /dev/ttyE1 -d -a
type=unknown_49
scroll.fastlines=25
scroll.slowlines=2
msg.default.attrs=color
msg.default.bg=black
msg.default.fg=white
msg.kernel.attrs=color
msg.kernel.bg=black
msg.kernel.fg=white
これで設定がわかりました。白背景に黒文字にしたければ次のようにします。
usl5p# wsconsctl -f /dev/ttyE1 -d -w msg.default.bg=white
msg.default.bg -> white
usl5p# wsconsctl -f /dev/ttyE1 -d -w msg.default.fg=black
msg.default.fg -> black
この設定をwscons.confのsetvarで書いてやればいいみたいですね。

起動時に試してみたら、確かに文字の所は設定が反映されて白背景に黒文字ですけれど、それ以外のスペースの部分は黒いままだったりして... まぁ、ログインしてCtrl-lで全面描画されるので良いんですけど。そもそもの背景色を設定する方法がほかにあるのかもしれません。

設定をまとめておきましょう。

カーネル (実際に必要なのは最後の一行だけですけど)
n601# diff -u GENERIC USL-5P.nfs
--- GENERIC     2013-01-05 18:03:35.000000000 +0000
+++ USL-5P.nfs  2013-01-05 18:06:35.000000000 +0000
@@ -175,8 +175,8 @@

 # Kernel root file system and dump configuration.
 #config                netbsd  root on ? type ?
-config         netbsd  root on wd0a type ffs
-#config                netbsd  root on ? type nfs
+#config                netbsd  root on wd0a type ffs
+config         netbsd  root on ? type nfs


 #
@@ -224,8 +224,8 @@
 # The 0x0001 flag force the driver to use DMA, even if the driver doesn't know
 # how to set up DMA modes for this chip. This may work, or may cause
 # a machine hang with some controllers.
-pciide*        at pci? dev ? function ? flags 0x0000   # GENERIC pciide driver
-acardide*      at pci? dev ? function ?        # Acard IDE controllers
+#pciide*       at pci? dev ? function ? flags 0x0000   # GENERIC pciide driver
+#acardide*     at pci? dev ? function ?        # Acard IDE controllers

 wdc0   at obio? port 0x14000000 irq 10         # CF
 #wdc1  at obio? port 0x18000000 irq 9          # iConnect
@@ -477,3 +477,14 @@
 # wscons pseudo-devices
 pseudo-device  wsmux                   # mouse & keyboard multiplexor
 #pseudo-device wsfont
+
+options        WSDISPLAY_CUSTOM_OUTPUT # color customization from wsconsctl(8)
+options        WSDISPLAY_CUSTOM_BORDER # custom border colors via wsconsctl(8)
+#options       WSDISPLAY_BORDER_COLOR=WSCOL_BLUE       # default color
+options        WSDISPLAY_COMPAT_PCVT           # emulate some ioctls
+options        WSDISPLAY_COMPAT_SYSCONS        # emulate some ioctls
+options        WSDISPLAY_COMPAT_USL            # wsconscfg VT handling
+options        WSDISPLAY_COMPAT_RAWKBD         # can get raw scancodes
+#options       WSDISPLAY_DEFAULTSCREENS=4
+options        WSDISPLAY_SCROLLSUPPORT
+options        WSEMUL_VT100            # VT100 / VT220 emulation
/etc/rc.conf
wscons=YES
/etc/ttys
console "/usr/libexec/getty std.9600"   vt220   on secure
constty "/usr/libexec/getty std.9600"   vt220   off secure
ttyE0   "/usr/libexec/getty Pc"         vt220   off secure
ttyE1   "/usr/libexec/getty Pc"         vt220   on secure
ttyE2   "/usr/libexec/getty Pc"         vt220   off secure
ttyE3   "/usr/libexec/getty Pc"         vt220   off secure
tty00   "/usr/libexec/getty std.9600"   unknown off secure
tty01   "/usr/libexec/getty std.9600"   unknown off secure
tty02   "/usr/libexec/getty std.9600"   unknown off secure
tty03   "/usr/libexec/getty std.9600"   unknown off secure
tty04   "/usr/libexec/getty std.9600"   unknown off secure
tty05   "/usr/libexec/getty std.9600"   unknown off secure
tty06   "/usr/libexec/getty std.9600"   unknown off secure
tty07   "/usr/libexec/getty std.9600"   unknown off secure

/etc/wscons.conf (screensの部分とsetvarの部分を抜粋)
#screen 0       -       vt100
screen  1       -       vt100
#screen 2       -       vt100
#screen 3       -       vt100
#screen 4       -       -

setvar ttyE1    msg.default.bg  white
setvar ttyE1    msg.default.fg  black

USL-5PにNetBSD/landiskをインストール (NetBSD 6.0.1)
2013/01/02(水) 17:39 NetBSD はてブ情報 はてブに登録 はてブ数

NetBSD/landiskをUSL-5Pで久しぶりに動かしました。
前回が2006年9月ですから、6年3か月ぶりですか。

あまりに久しぶりなのでメモしておきます。

なにはなくともシリアルコンソールを取らねばなりません。

そしてそのためにはプラスねじを一本外し、カバーを外す必要があります。
カバーは固く、少しの勇気をもってLANポート側からフロントのスイッチ側にカバーをスライドさせます。

シリアルポートはボード上のボタン電池の近所にある四つの穴ですね。
三角形のマーク(▲)が1番ポートです。
ピン番号内容
1番3.3V
2番TxD
3番RxD
4番GND
スルーホールなのでピンヘッダをはんだ付けする方法もありますが、LANTANK用のシリアルケーブルやサンハヤトのTTW-200のようなコンタクトピンになっているケーブルを使うと抜き差しが便利です。TTW-200だと少し太いかなぁ。今度買ってみよう。
今回はLANTANK用のシリアルケーブルを使いました。ただし、このケーブルだとTxD, RxDのピン配置が逆なので、一度ぜんぶピンごと抜いてさしなおす必要があります。

オリジナルのピン配置を書いておきます。グレーとイエローを入れ替えるんですね。
ピン番号内容
1番3.3Vオレンジ
2番RxDグレー
3番TxDイエロー
4番GNDホワイト
5番なし
ケーブルの準備ができたらテストしてみましょう。スピードは9600bpsです。

前回はどういうわけかUSL-5Pですべての作業をしていたみたいですが、作業効率も考えるとIntelマシンのパワーを使うのが何かと楽ちんです。今回はVMware Player上のNetBSD 6.0.1をThinkPadに接続したコンパクトフラッシュリーダライタを経由してコンパクトフラッシュにNetBSDをインストールしました。

以前のインストールメモです

使用したCFはSanDiskの256MB CFです。容量的にはkernel, base, etc, modulesを展開しておわりですね。compを入れたらあふれました...

準備として、VMwareに母艦のCFを見せる設定をVMware側に行っておきましょう。

NetBSD/landiskのリリース物を入手し、VMware側で展開しておきます。

最初は、CFのパーティションをつぶします。ddでゼロを書き込みます。
nb601# dd if=/dev/zero of=/dev/rsd0d bs=1k count=10
10+0 records in
10+0 records out
10240 bytes transferred in 0.125 secs (81920 bytes/sec)
次にMBRを書き込みます。先ほど展開しておいたNetBSD/landiskのmbrを書き込みます。landiskはi386ばりにMBRを解釈してくれて、MBR->ブートローダ->カーネルをFFSからブートします。MS-DOSパーティションやLinux ext3パーティションなどは不要です。
nb601# dd if=./usr/mdec/mbr of=/dev/rsd0d bs=512 count=1
1+0 records in
1+0 records out
512 bytes transferred in 0.019 secs (26947 bytes/sec)
fdiskでパーティションを切ります。パーティション0に対してシリンダの32番目から全体をNetBSD区画にしてしまいます。
nb601# fdisk -0 -u sd0
fdisk: Cannot determine the number of heads
Disk: /dev/rsd0d
NetBSD disklabel disk geometry:
cylinders: 245, heads: 64, sectors/track: 32 (2048 sectors/cylinder)
total sectors: 501760

BIOS disk geometry:
cylinders: 245, heads: 64, sectors/track: 32 (2048 sectors/cylinder)
total sectors: 501760

Partitions aligned to 2048 sector boundaries, offset 32

Do you want to change our idea of what BIOS thinks? [n]

Partition 0:
<UNUSED>
The data for partition 0 is:
<UNUSED>
sysid: [0..255 default: 169]
start: [0..245cyl default: 32, 0cyl, 0MB]
size: [0..245cyl default: 501728, 245cyl, 245MB]
bootmenu: [] NetBSD

Installed bootfile doesn't support required options.
Update the bootcode from /usr/mdec/mbr_bootsel? [n]

We haven't written the MBR back to disk yet.  This is your last chance.
Partition table:
0: NetBSD (sysid 169)
    bootmenu: NetBSD
    start 32, size 501728 (245 MB, Cyls 0-244)
1: <UNUSED>
2: <UNUSED>
3: <UNUSED>
Bootselector disabled.
No active partition.
Should we write new partition table? [n] y
アクティブ領域を設定します。当然ですがパーティション0をアクティブにします。
nb601# fdisk -a sd0
Disk: /dev/rsd0d
NetBSD disklabel disk geometry:
cylinders: 245, heads: 64, sectors/track: 32 (2048 sectors/cylinder)
total sectors: 501760

BIOS disk geometry:
cylinders: 245, heads: 64, sectors/track: 32 (2048 sectors/cylinder)
total sectors: 501760

Partitions aligned to 2048 sector boundaries, offset 32

Partition table:
0: NetBSD (sysid 169)
    bootmenu: NetBSD
    start 32, size 501728 (245 MB, Cyls 0-244)
1: <UNUSED>
2: <UNUSED>
3: <UNUSED>
Bootselector disabled.
No active partition.
Do you want to change the active partition? [n] y
Choosing 4 will make no partition active.
active partition: [0..4 default: 4] 0
Are you happy with this choice? [n] y

We haven't written the MBR back to disk yet.  This is your last chance.
Should we write new partition table? [n] y
disklabelを書きます。お好みです。swapをどうしようかと思ったのですが、FFS上のファイルをスワップにしてもいいですし、いざとなったらNFS上にスワップを作っちゃえばいいや、ということで少しでも容量を稼ぎます。
nb601# disklabel sd0
# /dev/rsd0d:
type: SCSI
disk: MCR   HS-CF
label: fictitious
flags: removable
bytes/sector: 512
sectors/track: 32
tracks/cylinder: 64
sectors/cylinder: 2048
cylinders: 245
total sectors: 501760
rpm: 3600
interleave: 1
trackskew: 0
cylinderskew: 0
headswitch: 0           # microseconds
track-to-track seek: 0  # microseconds
drivedata: 0

4 partitions:
#        size    offset     fstype [fsize bsize cpg/sgs]
 a:    501728        32     4.2BSD      0     0     0  # (Cyl.      0*-    244)
 c:    501728        32     unused      0     0        # (Cyl.      0*-    244)
 d:    501760         0     unused      0     0        # (Cyl.      0 -    244)
nb601# disklabel -i -I sd0
Enter '?' for help
partition> a
Filesystem type [?] [4.2BSD]:
Start offset ('x' to start after partition 'x') [0.015625c, 32s, 0.015625M]:
Partition size ('$' for all remaining) [244.984375c, 501728s, 244.984375M]:
partition> P
4 partitions:
#        size    offset     fstype [fsize bsize cpg/sgs]
 a:    501728        32     4.2BSD      0     0     0  # (Cyl.      0*-    244)
 d:    501760         0     unused      0     0        # (Cyl.      0 -    244)
partition> c
Filesystem type [?] [unused]:
Start offset ('x' to start after partition 'x') [0c, 0s, 0M]: 32
Partition size ('$' for all remaining) [0c, 0s, 0M]: $
 c:    501728        32     unused      0     0        # (Cyl.      0*-    244)
partition> P
4 partitions:
#        size    offset     fstype [fsize bsize cpg/sgs]
 a:    501728        32     4.2BSD      0     0     0  # (Cyl.      0*-    244)
 c:    501728        32     unused      0     0        # (Cyl.      0*-    244)
 d:    501760         0     unused      0     0        # (Cyl.      0 -    244)
partition> W
Label disk [n]? y
Label written
partition> Q
NetBSDパーティションをnewfsでフォーマットします。
(なぜか手順が残ってなかったなー)
nb601# newfs /dev/rsd0a
作成したsd0aにinstallbootでプライマリブートローダをぶち込みます。
nb601# installboot -m landisk -v /dev/rsd0a ./usr/mdec/bootxx_ffsv1
File system:         /dev/rsd0a
Primary bootstrap:   ./usr/mdec/bootxx_ffsv1
次にセカンダリブートローダです。こちらはファイルのコピーですからまずはsd0aをマウントします。
nb601# mount /dev/sd0a /mnt
セカンダリブートローダをコピーします。ちゃんとlandisk用のbootをつかいましょう。母艦のbootをコピーしないように。
nb601# cp ./usr/mdec/boot /mnt
次は配布物をインストールしていきます。
手元の環境ではGENERICカーネルも展開済みだったのでコピーしました。
ほんとうならpax -rzpe -f kern-GENERIC.tgzあたりですかね。
nb601# cp netbsd /mnt
base, etc, modulesを展開していきます。6系からmodulesを入れないといけませんねぇ。これを忘れると/sbin/initが起動しないんだったかな。
nb601# pax -rzpe -f /root/601/landisk/base.tgz; pax -rzpe -f /root/601/landisk/etc.tgz ; pax -rzpe -f /root/601/landisk/modules.tgz
MAKEDEVでデバイスを作っておきます。
nb601# cd dev
nb601# ./MAKEDEV all
/etc/fstabを書いておきます。起動するだけならtouch /etc/fstabでもいいかも。
nb601# cd ../etc
nb601# echo /dev/wd0a / ffs rw 1 1 > fstab
ここらへんまで来たらもう起動してもいいんですが、マルチユーザにしたければ/etc/rc.confにrc_configured=YESを書いてあげないといけません。
次の例ではラインエディタであるedを使っています。
nb601# ed rc.conf
515
/NO
# Use program=YES to enable program, NO to disable it. program_flags are
/
rc_configured=NO
s/NO/YES
rc_configured=YES
w
516
q
インストールは終わりです。
マウントポイントから離れて、アンマウントします。
nb601# cd /
nb601# umount /mnt
いざ、起動です。
SH IPL+g version 0.9, Copyright (C) 2000 Free Software Foundation, Inc.

This software comes with ABSOLUTELY NO WARRANTY; for details type `w'.
This is free software, and you are welcome to redistribute it under
certain conditions; type `l' for details.

2002/09/09 Making.  2004/09/08 I-O DATA NSU Update.
266:133:33 on base clock 22.22MHz and SDRAM 4 burst. CF boot.

PCIC initialization done.
MASTER:48bit LBA mode non support
Disk drive detected: SanDisk SDCFB-256 HDX 3.19     111702D2206F0252
LBA: 0007A800
DiskSize: 256901120Byte
PIO MODE1
Set Transfer Mode result: 50
> b
Set Transfer Mode result: 50
Initialize Device Parameters result: 50
IDLE result: 50

NetBSD MBR boot

NetBSD/landisk ffsv1 Primary Bootstrap

>> NetBSD/landisk Boot, Revision 1.0
Press return to boot now, any other key for boot menu
booting hd0a:netbsd - starting in 0
3409060+135044 [268048+257712]=0x3e202c
Start @ 0x8c001000 [1=0x8c362428-0x8c3e302c]...
Copyright (c) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
    2006, 2007, 2008, 2009, 2010, 2011, 2012
    The NetBSD Foundation, Inc.  All rights reserved.
Copyright (c) 1982, 1986, 1989, 1991, 1993
    The Regents of the University of California.  All rights reserved.

NetBSD 6.0.1 (GENERIC)
Model: I-O DATA LANDISK
total memory = 65536 KB
avail memory = 58416 KB
mainbus0 (root)
cpu0 at mainbus0: SH4 266.666 MHz PCLOCK 33.333 MHz
cpu0: 8KB/32B direct-mapped Instruction cache.
cpu0: 16KB/32B direct-mapped Data cache.
cpu0: U0, P0, P3 write-through; P1 write-through
cpu0: full-associative 4 ITLB, 64 UTLB entries
cpu0: multiple virtual storage mode, SQ access: kernel, wired 3
shpcic0 at mainbus0: Hitachi SH7751R PCI Controller (host bridge, revision 0x01)
pci0 at shpcic0
re0 at pci0 dev 0 function 0: RealTek 8139C+ 10/100BaseTX (rev. 0x20)
re0: interrupting at irq 5
re0: Ethernet address XX:XX:XX:XX:XX:XX
rlphy0 at re0 phy 0: Realtek internal PHY
rlphy0: 10baseT, 10baseT-FDX, 100baseTX, 100baseTX-FDX, auto
ohci0 at pci0 dev 2 function 0: NEC USB Host Controller (rev. 0x43)
ohci0: interrupting at irq 7
ohci0: OHCI version 1.0
usb0 at ohci0: USB revision 1.0
ohci1 at pci0 dev 2 function 1: NEC USB Host Controller (rev. 0x43)
ohci1: interrupting at irq 8
ohci1: OHCI version 1.0
usb1 at ohci1: USB revision 1.0
ehci0 at pci0 dev 2 function 2: NEC USB Host Controller (rev. 0x04)
ehci0: interrupting at irq 5
ehci0: companion controllers, 3 ports each: ohci0 ohci1
usb2 at ehci0: USB revision 2.0
shb0 at mainbus0
scif0 at shb0
scif0: console
rs5c313rtc0 at shb0: RICOH 5C313 real time clock
obio0 at mainbus0
wdc0 at obio0 port 0x14000000-0x1400000f irq 10
atabus0 at wdc0 channel 0
btn0 at obio0 irq 12: USL-5P buttons
pwrsw0 at obio0 irq 11: Power Switch
uhub0 at usb0: NEC OHCI root hub, class 9/0, rev 1.00/1.00, addr 1
uhub1 at usb1: NEC OHCI root hub, class 9/0, rev 1.00/1.00, addr 1
uhub2 at usb2: NEC EHCI root hub, class 9/0, rev 2.00/1.00, addr 1
wd0 at atabus0 drive 0
wd0: <SanDisk SDCFB-256>
wd0: 245 MB, 980 cyl, 16 head, 32 sec, 512 bytes/sect x 501760 sectors
boot device: wd0
root on wd0a dumps on wd0b
Wed Jan  2 19:38:48 UTC 2013
Starting root file system check:
/dev/rwd0a: file system is clean; not checking
Starting file system checks:
Setting tty flags.
Setting sysctl variables:
ddb.onpanic: 1 -> 0
Starting network.
/etc/rc: WARNING: $hostname not set.
IPv6 mode: host
Configuring network interfaces:.
Adding interface aliases:.
Building databases: dev, dev, utmp, utmpx, services.
Starting syslogd.
Mounting all filesystems...
Clearing temporary files.
Checking quotas: done.
Setting securelevel: kern.securelevel: 0 -> 1
/etc/rc: WARNING: No swap space configured!
/etc/rc.d/swap2 exited with code 1
Starting virecover.
Checking for core dump...
savecore: /dev/rwd0b: Device not configured
Jan  2 19:39:03  savecore: /dev/rwd0b: Device not configured
Starting local daemons:.
Updating motd.
postfix: rebuilding /etc/mail/aliases (missing /etc/mail/aliases.db)
newaliases: warning: valid_hostname: empty hostname
newaliases: fatal: unable to use my own hostname
Jan  2 19:39:06  postfix/sendmail[313]: fatal: unable to use my own hostname
/etc/rc.d/postfix exited with code 1
Starting inetd.
Starting cron.
The following components reported failures:
    /etc/rc.d/swap2 /etc/rc.d/postfix
See /var/run/rc.log for more information.
Wed Jan  2 19:39:07 UTC 2013

NetBSD/landisk (Amnesiac) (console)

login: root
Jan  2 19:39:13  login: ROOT LOGIN (root) on tty console
Copyright (c) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
    2006, 2007, 2008, 2009, 2010, 2011, 2012
    The NetBSD Foundation, Inc.  All rights reserved.
Copyright (c) 1982, 1986, 1989, 1991, 1993
    The Regents of the University of California.  All rights reserved.

NetBSD 6.0.1 (GENERIC)

Welcome to NetBSD!

Terminal type? [unknown] xterm
Terminal type is xterm.
We recommend that you create a non-root account and use su(1) for root access.
# uname -a
NetBSD  6.0.1 NetBSD 6.0.1 (GENERIC) landisk
#
ここまでくれば、あとはボチボチと設定していけばいいでしょう。