From: Bob Beck <beck@assurtech.com>
To: linuxppc-embedded@lists.linuxppc.org
Subject: Update: Booting Linux on a Custom PPC Board
Date: 02 Mar 2004 15:18:09 +1400 [thread overview]
Message-ID: <1078190289.4228.2.camel@budweiser> (raw)
Ok. Now its making it to start_ in boot/simple/head.S.
It jumps to relocate in relocate.S after doing some 6xx
specific code. In util.S, it enters but never finishes
the flush_data_cache. ????????
Bob
-----Forwarded Message-----
From: Bob Beck <beck@assurtech.com>
To: linuxppc-embedded@lists.linuxppc.org
Subject: Booting Linux on a Custom PPC Board
Date: 02 Mar 2004 12:58:54 +1400
I am booting Linux on a custom board and having many
problems. The board contains a PPC603E, flash, an
ethernet controller, and a serial chip.
Here is what I have done so far.
o Configured the kernel to support 6xx/7xx boards
o Introduced a new defined named "CONFIG_ATCNVMS"
o Modified kernel/setup.c so that early_init() would
skip the last 3 things it does that do not make
sense for my board.
o Added a new embed_config() function in arch/ppc/boot/simple
that populates a bd_t structure (from ppcboot.h)
o Added code to save registers r3-r7 at the beginning
of start_ in simple/head.S. Restored these registers
in relocate.S before the jump to 0.
o Updated the makefiles so that the zImage.embedded
would be created in the arch/ppc/boot/images directory.
We are writing our own boot loader code for a couple of reasons.
o U-Boot does not support our ethernet chip or serial chip.
o VxWorks is in flash and we cannot change that in the near future.
o The VxWorks boot loader initializes the hardware and
we run our custom boot loader from its shell.
Here are the steps taken by our custom boot loader.
o Malloc a piece of memory and copy the ram disk from a file
to the malloc'd memory.
o Malloc a piece of memory and copy the zImage.bin contents from
a file to memory.
powerpc-linux-objcopy -O binary zImage.embedded zImage.bin
o Prepare the registers
r3 = ptr to bd_t
r4 = ptr to initial ram disk bin in memory
r5 = ptr to end of initial ram disk
r6 = ptr to start of command line string
r7 = ptr to end of command line string
o Jump to the start address where the zImage.bin has been loaded
into memory.
In arch/ppc/boot/simple/head.S, I call a routine that blinks a light
(start_), but this light never blinks. I also call this routine
at __start in arch/ppc/kernel/head.S but the light never blinks.
I don't understand what to do at this point. In the past I
loaded the ram disk and vmlinux into memory and jumped to 0x10000.
Somebody on this list said that was guaranteed not to work.
However, the light did blink before the code had problems in
mmu initialization.
Regards,
Bob Beck
beck@assurtech.com
** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/
next reply other threads:[~2004-03-02 1:18 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-03-02 1:18 Bob Beck [this message]
-- strict thread matches above, loose matches on Subject: below --
2005-03-23 19:45 Update: Booting Linux on a Custom PPC Board Don Russell
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1078190289.4228.2.camel@budweiser \
--to=beck@assurtech.com \
--cc=linuxppc-embedded@lists.linuxppc.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).