From owner-freebsd-arm@freebsd.org Tue Apr 19 15:09:36 2016 Return-Path: Delivered-To: freebsd-arm@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id D5F34B13377 for ; Tue, 19 Apr 2016 15:09:36 +0000 (UTC) (envelope-from freebsd-arm@dino.sk) Received: from mailhost.netlabit.sk (mailhost.netlabit.sk [84.245.65.72]) (using TLSv1 with cipher DHE-RSA-CAMELLIA256-SHA (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 7FAEA18F1; Tue, 19 Apr 2016 15:09:35 +0000 (UTC) (envelope-from freebsd-arm@dino.sk) Received: from zeta.dino.sk (fw1.dino.sk [84.245.95.252]) (AUTH: LOGIN milan) by mailhost.netlabit.sk with ESMTPA; Tue, 19 Apr 2016 17:09:32 +0200 id 00DAE021.57164A2C.0000577C Date: Tue, 19 Apr 2016 17:09:32 +0200 From: Milan Obuch To: freebsd-arm@freebsd.org Cc: Ian Lepore , Emmanuel Vadot , Erich Dollansky Subject: Re: Orange Pi One Message-ID: <20160419170932.3fe2b709@zeta.dino.sk> In-Reply-To: <1461075584.1232.13.camel@freebsd.org> References: <20160413232414.3a37907e@zeta.dino.sk> <20160414062820.7b907ba9@X220.alogt.com> <20160414064405.202e4eef@zeta.dino.sk> <20160418094916.10dc9ae8@zeta.dino.sk> <20160418174918.33d3d19e4105eb737d17b122@bidouilliste.com> <20160418210108.4047c526@zeta.dino.sk> <20160419092012.0ad4ad2d@zeta.dino.sk> <20160419093408.2f6d8d6472b09298f1e08ecb@bidouilliste.com> <20160419095358.351c74b3@zeta.dino.sk> <1461075584.1232.13.camel@freebsd.org> X-Mailer: Claws Mail 3.13.2 (GTK+ 2.24.29; i386-portbld-freebsd10.3) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-BeenThere: freebsd-arm@freebsd.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: "Porting FreeBSD to ARM processors." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 19 Apr 2016 15:09:36 -0000 On Tue, 19 Apr 2016 08:19:44 -0600 Ian Lepore wrote: > On Tue, 2016-04-19 at 09:53 +0200, Milan Obuch wrote: > > On Tue, 19 Apr 2016 09:34:08 +0200 > > Emmanuel Vadot wrote: > > > > > On Tue, 19 Apr 2016 09:20:12 +0200 > > > Milan Obuch wrote: > > > > > > > > > > > One step further - compiled ubldr as part of buildworld, tried, > > > > and > > > > found I need ubldr.bin to start boot process, ubldr just keeps > > > > crashing with following: > > > > > > > > Booting from: mmc 0 ubldr > > > > reading ubldr > > > > 235312 bytes read in 63 ms (3.6 MiB/s) > > > > ## Starting application at 0x01000098 ... > > > > undefined instruction > > > > pc : [<01c0f00c>] lr : [<5ff77138>] > > > > reloc pc : [] lr : [<4a007138>] > > > > sp : 5bf4ba70 ip : 00000030 fp : 5ff76ffc > > > > r10: 00000001 r9 : 5bf4fee8 r8 : 00000000 > > > > r7 : 00000001 r6 : 5bf513e0 r5 : 01000098 r4 : > > > > 00000000 r3 : 00000001 r2 : 01c28000 r1 : 5bf513e4 > > > > r0 : 00000000 Flags: nZCv IRQs off FIQs off Mode SVC_32 > > > > Resetting CPU ... > > > > > > > > resetting ... > > > > > > > > but ubldr.bin works (command typed manually): > > > > > > > > => fatload mmc 0 0x42000000 ubldr.bin > > > > reading ubldr.bin > > > > 192096 bytes read in 58 ms (3.2 MiB/s) > > > > => go 0x42000000 > > > > ## Starting application at 0x42000000 ... > > > > Consoles: U-Boot console > > > > Compatible U-Boot API signature found @0x5bf504c8 > > > > > > > > FreeBSD/arm U-Boot loader, Revision 1.2 > > > > (root@zeta.dino.sk, Tue Apr 19 06:33:11 CEST 2016) > > > > > > > > DRAM: 512MB > > > > MMC Device 1 not found > > > > Number of U-Boot devices: 1 > > > > U-Boot env: loaderdev='mmc 0' > > > > Found U-Boot device: disk > > > > Checking unit=0 slice= partition=... good. > > > > Booting from disk0s1: > > > > - > > > > can't load 'kernel' > > > > > > > > Type '?' for a list of commands, 'help' for more detailed > > > > help. > > > > loader> > > > > > > > > Now I can type loader command, so I can try to load kernel if I > > > > had > > > > one (I tried to build it from stock FreeBSD sources, but > > > > something > > > > was wrong, I must figure why buildkernel did not produce > > > > kernel... > > > > just testing now, waiting where it breaks). > > > > > > > > Milan > > > > > > For ubldr to work you need to set UBLDR_LOADADDR variable to the > > > correct address. > > > > > > > Where is this defined? Or should be? Not top important issue now, as > > I > > can continue with ubldr.bin for some time, but I still would like to > > check it. > > > > Actually, ubldr (the elf version) shouldn't even exist anymore. Once > I got the relocation worked out for ubldr.bin, the plan was always to > eliminate the elf version and have just the .bin file. I left the elf > file around to allow time for crochet and other scripts to adjust > (which I think probably never happened). > > FreeBSD image building (for snapshots and releases) was supposed to > transition to a new mechanism which built a single world for all > supported systems, and a board-specific kernel for each supported > board. The only way to build a single world for all images is to > eliminate the elf ubldr which has to be compiled differently for each > board. > > -- Ian > OK, so using ubldr.bin is actually not workaround but intended way of doing things? Even better. I'll keep it this way then. However, I could not find a way to load kernel (downloaded from Emmanuel's site for test at a moment, I am building new world, maybe even kernel just now, but it is slow with 11 - clang is building for hours and hours) so it run - all I get is FreeBSD/arm U-Boot loader, Revision 1.2 (root@zeta.dino.sk, Tue Apr 19 06:33:11 CEST 2016) DRAM: 512MB MMC Device 1 not found Number of U-Boot devices: 1 U-Boot env: loaderdev='mmc 0' Found U-Boot device: disk Checking unit=0 slice= partition=... good. Booting from disk0s2a: / /boot/kernel/kernel data=0x62ea24+0x1215dc syms=[0x4+0x8a720+0x4+0x9e5f2] Hit [Enter] to boot immediately, or any other key for command prompt. Booting [/boot/kernel/kernel]... Kernel entry at 0x0x42200100... Kernel args: (null) and hang. But it apparently works for him, so why not for me? Do we have some good description of booting process with some details how fdt gets loaded along with kernel and how kernel finds needed bits? As all I want now is start kernel, I have only two files in FreeBSD partiion on my SD - /boot/dtb/orangepi.dtb and /boot/kernel/kernel. Maybe I need something more, like /boot/loader.conf? I hope somebody could enlighten me... Milan