linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* Basics -- what tools for Walnut?
@ 2002-06-05 17:36 Dave Strout
  2002-06-05 17:43 ` Mark Hatle
                   ` (2 more replies)
  0 siblings, 3 replies; 9+ messages in thread
From: Dave Strout @ 2002-06-05 17:36 UTC (permalink / raw)
  To: linuxppc-embedded


I think I'm missing a basic concept here -- I'm about to do some work on
a Walnut system, so  I started by loading up the HardHat Linux that came
with the Walnut onto my intel desktop, then grabbing the
linuxppc_2_4_devel kernel via rsync.  When I try to compile, gas startes
to complain about "unknown option '-m405'".

I tried running /opt/hardhat/devkit/ppc/4xx/bin/ppc_4xx-as -m405, and
sure enough, it doesn't know the 405.  Nor does the gas that I built
from binutils 2.10.1 with --target-powerpc.

So, is there a patch I should be applying before building the
cross-compile environment, or a specific set of tools somewhere, or what
am I missing?

thanks,
dave.


** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: Basics -- what tools for Walnut?
  2002-06-05 17:36 Basics -- what tools for Walnut? Dave Strout
@ 2002-06-05 17:43 ` Mark Hatle
  2002-06-05 17:49 ` Frank Rowand
  2002-06-05 19:16 ` Wolfgang Denk
  2 siblings, 0 replies; 9+ messages in thread
From: Mark Hatle @ 2002-06-05 17:43 UTC (permalink / raw)
  To: Dave Strout; +Cc: linuxppc-embedded


The version of HardHat Linux that came with your walnut was created to match the
requirements of the kernel also shipped with Hard Hat Linux.

The current _devel kernel requires a newer version of binutils that understands
the -m405 architecture.  Either use the kernel shipped w/ Hard Hat Linux, or you
will need to get a newer tool chain.  (Either build it yourself or purchase it
from MontaVista...)

--Mark
(Speaking for myself, not MontaVista whom I work for.)

Dave Strout wrote:
>
> I think I'm missing a basic concept here -- I'm about to do some work on
> a Walnut system, so  I started by loading up the HardHat Linux that came
> with the Walnut onto my intel desktop, then grabbing the
> linuxppc_2_4_devel kernel via rsync.  When I try to compile, gas startes
> to complain about "unknown option '-m405'".
>
> I tried running /opt/hardhat/devkit/ppc/4xx/bin/ppc_4xx-as -m405, and
> sure enough, it doesn't know the 405.  Nor does the gas that I built
> from binutils 2.10.1 with --target-powerpc.
>
> So, is there a patch I should be applying before building the
> cross-compile environment, or a specific set of tools somewhere, or what
> am I missing?
>
> thanks,
> dave.
>

** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: Basics -- what tools for Walnut?
  2002-06-05 17:36 Basics -- what tools for Walnut? Dave Strout
  2002-06-05 17:43 ` Mark Hatle
@ 2002-06-05 17:49 ` Frank Rowand
  2002-06-05 18:14   ` Dan Malek
  2002-06-05 19:16 ` Wolfgang Denk
  2 siblings, 1 reply; 9+ messages in thread
From: Frank Rowand @ 2002-06-05 17:49 UTC (permalink / raw)
  To: Dave Strout; +Cc: linuxppc-embedded


Dave Strout wrote:
>
> I think I'm missing a basic concept here -- I'm about to do some work on
> a Walnut system, so  I started by loading up the HardHat Linux that came
> with the Walnut onto my intel desktop, then grabbing the
> linuxppc_2_4_devel kernel via rsync.  When I try to compile, gas startes
> to complain about "unknown option '-m405'".
>
> I tried running /opt/hardhat/devkit/ppc/4xx/bin/ppc_4xx-as -m405, and
> sure enough, it doesn't know the 405.  Nor does the gas that I built
> from binutils 2.10.1 with --target-powerpc.
>
> So, is there a patch I should be applying before building the
> cross-compile environment, or a specific set of tools somewhere, or what
> am I missing?

I suspect that is a fairly old tool chain that you are using.
Try modifying arch/ppc/Makefile to use

  -mcpu=403

instead of

  -mcpu=405

If you subscribe to the MontaVista product, the current compiler will
work properly with linuxppc_2_4_devel.

-Frank
--
Frank Rowand <frank_rowand@mvista.com>
MontaVista Software, Inc

** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: Basics -- what tools for Walnut?
  2002-06-05 17:49 ` Frank Rowand
@ 2002-06-05 18:14   ` Dan Malek
  2002-06-05 18:24     ` Dave Strout
  0 siblings, 1 reply; 9+ messages in thread
From: Dan Malek @ 2002-06-05 18:14 UTC (permalink / raw)
  To: frowand; +Cc: Dave Strout, linuxppc-embedded


Frank Rowand wrote:

> I suspect that is a fairly old tool chain that you are using.

In the past, the practice was to inform people when changes were made
that required a minimum revision of tools to operate properly.
Simply telling people "your toolchain is too old" isn't helpful.....
What version of tools is required to build this properly?  Why
doesn't the check in comment indicate this information when the
change was made?

> Try modifying arch/ppc/Makefile to use
>
>   -mcpu=403

Or, just remove it since it doesn't perform any useful function.  On
the newer tools, it's required to allow the assembler to not bitch about
4xx unique instructions, another non-useful function, IMHO.

Thanks.

	-- Dan


** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: Basics -- what tools for Walnut?
  2002-06-05 18:14   ` Dan Malek
@ 2002-06-05 18:24     ` Dave Strout
  0 siblings, 0 replies; 9+ messages in thread
From: Dave Strout @ 2002-06-05 18:24 UTC (permalink / raw)
  To: linuxppc-embedded


It's all good -- I didn't realize there was a newer binutils.  2.12
seems to do the trick

thanks,
dave.

Dan Malek wrote:

>
> Frank Rowand wrote:
>
>> I suspect that is a fairly old tool chain that you are using.
>
>
> In the past, the practice was to inform people when changes were made
> that required a minimum revision of tools to operate properly.
> Simply telling people "your toolchain is too old" isn't helpful.....
> What version of tools is required to build this properly?  Why
> doesn't the check in comment indicate this information when the
> change was made?
>
>> Try modifying arch/ppc/Makefile to use
>>
>>   -mcpu=403
>
>
> Or, just remove it since it doesn't perform any useful function.  On
> the newer tools, it's required to allow the assembler to not bitch about
> 4xx unique instructions, another non-useful function, IMHO.
>
> Thanks.
>
>     -- Dan
>
>
>


** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: Basics -- what tools for Walnut?
  2002-06-05 17:36 Basics -- what tools for Walnut? Dave Strout
  2002-06-05 17:43 ` Mark Hatle
  2002-06-05 17:49 ` Frank Rowand
@ 2002-06-05 19:16 ` Wolfgang Denk
  2002-06-05 20:16   ` Can compile, now on to booting Dave Strout
  2 siblings, 1 reply; 9+ messages in thread
From: Wolfgang Denk @ 2002-06-05 19:16 UTC (permalink / raw)
  To: Dave Strout; +Cc: linuxppc-embedded


In message <3CFE4C3A.4070604@linuxfoundary.com> you wrote:
>
> I think I'm missing a basic concept here -- I'm about to do some work on
> a Walnut system, so  I started by loading up the HardHat Linux that came
> with the Walnut onto my intel desktop, then grabbing the
> linuxppc_2_4_devel kernel via rsync.  When I try to compile, gas startes
> to complain about "unknown option '-m405'".
...
> So, is there a patch I should be applying before building the
> cross-compile environment, or a specific set of tools somewhere, or what
> am I missing?

Have a look at our ELDK, see http://www.denx.de/ELDK/

We support a couple of 405 boards (although the walnut is not one  of
those).

Wolfgang Denk

--
Software Engineering:  Embedded and Realtime Systems,  Embedded Linux
Phone: (+49)-8142-4596-87  Fax: (+49)-8142-4596-88  Email: wd@denx.de
"Faith: not *wanting* to know what is true."    - Friedrich Nietzsche

** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Can compile, now on to booting
  2002-06-05 19:16 ` Wolfgang Denk
@ 2002-06-05 20:16   ` Dave Strout
  2002-06-06  4:06     ` Donald White
  0 siblings, 1 reply; 9+ messages in thread
From: Dave Strout @ 2002-06-05 20:16 UTC (permalink / raw)
  To: linuxppc-embedded


Thanks all for the help with the toolchain -- I'm now cranking out ppc
code.

Now to boot.  What I'm actually trying to do is replace a VxWorks
environment on one of my companies products with Linux. The unit is
405GP based, and pretty close to a walnut, as far as I can tell
(comparing the mem map in the docs with the 405gp.h file in the
kernel).  I'm hoping to get away with using the existing boot monitor,
at least in the short term.  The monitor has the ability to load an ELF
executable & jump to it, but I'm not getting very far beyond that -- in
fact it crashes with the pc at the first instruction.  I've tried my
freshly-built 2.4.18 kernel, and the ppcboot executable, and they both
crash on the first instruction.

I don't have a hardware debugger for this, so I'm sort of at a loss.
 There are some LED's on the front that I could try & write some asm to
blink as I go along, but since I hang on the first instruction, I'm not
sure that would help.......

All thoughts greatly appreciated.

dave.


Dumps:

Linux:
ftp 134.141.133.254:vmlinux to SDRAM size=1430968
Booting system S/W at entry 0xc0000000
Starting at 0xc0000000...


program
Exception current instruction address: 0xc0000000
Machine Status Register: 0x00029200
Condition Register: 0x24200082
Task: 0x1f1a8e0 "tBoot"

r0     =   c034dc   sp     =  1f1a4d0   r2     =        0   r3
=        0
r4     =  1f80000   r5     =  1f1a8e0   r6     =    29200   r7     =
1200
r8     =       20   r9     =   ca0000   r10    =        4   r11
=        0
r12    =        0   r13    =        0   r14    =        0   r15
=        0
r16    =        0   r17    =        0   r18    =        0   r19
=        0
r20    =        0   r21    =        0   r22    =        0   r23
=        0
r24    =        0   r25    =        0   r26    =        0   r27    =
ca0000
r28    =   ca0000   r29    = c0000000   r30    =  1ffffc8   r31    =
c0000000
msr    =    29200   lr     =   c034e4   ctr    =        0   pc     =
c0000000
cr     = 24200082   xer    =        0

ppcboot:

ftp 134.141.133.254:ppcboot to SDRAM size=186232 + 4
Booting system S/W at entry 0xfff80000
Starting at 0xfff80000...


program
Exception current instruction address: 0xfff80000
Machine Status Register: 0x00029200
Condition Register: 0x24200082
Task: 0x1f1a8e0 "tBoot"

r0     =   c034dc   sp     =  1f1a4d0   r2     =        0   r3
=        0
r4     =  1f80000   r5     =  1f1a8e0   r6     =    29200   r7     =
1200
r8     =       20   r9     =   ca0000   r10    =        4   r11
=        0
r12    =        0   r13    =        0   r14    =        0   r15
=        0
r16    =        0   r17    =        0   r18    =        0   r19
=        0
r20    =        0   r21    =        0   r22    =        0   r23
=        0
r24    =        0   r25    =        0   r26    =        0   r27    =
ca0000
r28    =   ca0000   r29    = fff80000   r30    =  1ffffc8   r31    =
fff80000
msr    =    29200   lr     =   c034e4   ctr    =        0   pc     =
fff80000
cr     = 24200082   xer    =        0

Objdump says:
[dstrout@dstrout dstrout]$ ~/tools/bin/powerpc-linux-objdump -D ppcboot
| head -20

ppcboot:     file format elf32-powerpc

Disassembly of section .resetvec:

fffffffc <.resetvec>:
fffc:    4b f8 01 04     b    fff80100 <_start>
Disassembly of section .text:

fff80000 <version_string-0x4>:
fff80000:    27 05 19 56     dozi    r24,r5,6486

fff80004 <version_string>:
fff80004:    50 50 43 42     rlwimi    r16,r2,8,13,1
fff80008:    6f 6f 74 20     xoris    r15,r27,29728
fff8000c:    31 2e 31 2e     addic    r9,r14,12590
fff80010:    35 20 28 4a     addic.    r9,r0,10314
fff80014:    75 6e 20 20     andis.    r14,r11,8224
fff80018:    35 20 32 30     addic.    r9,r0,12848
fff8001c:    30 32 20 2d     addic    r1,r18,8237

[dstrout@dstrout dstrout]$ ~/tools/bin/powerpc-linux-objdump -D vmlinux
| head -20

vmlinux:     file format elf32-powerpc

Disassembly of section .text:

c0000000 <_start>:
c0000000:    7c 7f 1b 78     mr    r31,r3
c0000004:    7c 9e 23 78     mr    r30,r4
c0000008:    7c bd 2b 78     mr    r29,r5
c000000c:    7c dc 33 78     mr    r28,r6
c0000010:    7c fb 3b 78     mr    r27,r7
c0000014:    3b 00 00 00     li    r24,0
c0000018:    48 00 23 49     bl    c0002360 <initial_mmu>

c000001c <turn_on_mmu>:
c000001c:    38 00 10 32     li    r0,4146
c0000020:    7c 1b 03 a6     mtsrr1    r0
c0000024:    3c 00 c0 00     lis    r0,-16384
c0000028:    60 00 22 c0     ori    r0,r0,8896
c000002c:    7c 1a 03 a6     mtsrr0    r0


** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: Can compile, now on to booting
  2002-06-05 20:16   ` Can compile, now on to booting Dave Strout
@ 2002-06-06  4:06     ` Donald White
  2002-06-06 13:00       ` Dave Strout
  0 siblings, 1 reply; 9+ messages in thread
From: Donald White @ 2002-06-06  4:06 UTC (permalink / raw)
  To: linuxppc-embedded


I did this once on a mpc860 board.  It involved running the uncompressed
kernel image through vxhack.c from Dan Malek with a few fixes since the
segments seemed to have moved around.  The VxWorks loader would then
load the hacked image through bootp or tftp.  I also had to have one of
the Linux bootloader files initialize a bd_t structure.  I was able to
poke around in memory and find where the VxWorks loader was keeping the
environment.

Don

Dave Strout wrote:

>
> Thanks all for the help with the toolchain -- I'm now cranking out ppc
> code.
>
> Now to boot.  What I'm actually trying to do is replace a VxWorks
> environment on one of my companies products with Linux. The unit is
> 405GP based, and pretty close to a walnut, as far as I can tell
> (comparing the mem map in the docs with the 405gp.h file in the
> kernel).  I'm hoping to get away with using the existing boot monitor,
> at least in the short term.  The monitor has the ability to load an ELF
> executable & jump to it, but I'm not getting very far beyond that -- in
> fact it crashes with the pc at the first instruction.  I've tried my
> freshly-built 2.4.18 kernel, and the ppcboot executable, and they both
> crash on the first instruction.
>
> I don't have a hardware debugger for this, so I'm sort of at a loss.
> There are some LED's on the front that I could try & write some asm to
> blink as I go along, but since I hang on the first instruction, I'm not
> sure that would help.......
>
> All thoughts greatly appreciated.
>
> dave.
>
>
> Dumps:
>
> Linux:
> ftp 134.141.133.254:vmlinux to SDRAM size=1430968
> Booting system S/W at entry 0xc0000000
> Starting at 0xc0000000...
>
>
> program
> Exception current instruction address: 0xc0000000
> Machine Status Register: 0x00029200
> Condition Register: 0x24200082
> Task: 0x1f1a8e0 "tBoot"
>
> r0     =   c034dc   sp     =  1f1a4d0   r2     =        0   r3
> =        0
> r4     =  1f80000   r5     =  1f1a8e0   r6     =    29200   r7     =
> 1200
> r8     =       20   r9     =   ca0000   r10    =        4   r11
> =        0
> r12    =        0   r13    =        0   r14    =        0   r15
> =        0
> r16    =        0   r17    =        0   r18    =        0   r19
> =        0
> r20    =        0   r21    =        0   r22    =        0   r23
> =        0
> r24    =        0   r25    =        0   r26    =        0   r27    =
> ca0000
> r28    =   ca0000   r29    = c0000000   r30    =  1ffffc8   r31    =
> c0000000
> msr    =    29200   lr     =   c034e4   ctr    =        0   pc     =
> c0000000
> cr     = 24200082   xer    =        0
>
> ppcboot:
>
> ftp 134.141.133.254:ppcboot to SDRAM size=186232 + 4
> Booting system S/W at entry 0xfff80000
> Starting at 0xfff80000...
>
>
> program
> Exception current instruction address: 0xfff80000
> Machine Status Register: 0x00029200
> Condition Register: 0x24200082
> Task: 0x1f1a8e0 "tBoot"
>
> r0     =   c034dc   sp     =  1f1a4d0   r2     =        0   r3
> =        0
> r4     =  1f80000   r5     =  1f1a8e0   r6     =    29200   r7     =
> 1200
> r8     =       20   r9     =   ca0000   r10    =        4   r11
> =        0
> r12    =        0   r13    =        0   r14    =        0   r15
> =        0
> r16    =        0   r17    =        0   r18    =        0   r19
> =        0
> r20    =        0   r21    =        0   r22    =        0   r23
> =        0
> r24    =        0   r25    =        0   r26    =        0   r27    =
> ca0000
> r28    =   ca0000   r29    = fff80000   r30    =  1ffffc8   r31    =
> fff80000
> msr    =    29200   lr     =   c034e4   ctr    =        0   pc     =
> fff80000
> cr     = 24200082   xer    =        0
>
> Objdump says:
> [dstrout@dstrout dstrout]$ ~/tools/bin/powerpc-linux-objdump -D ppcboot
> | head -20
>
> ppcboot:     file format elf32-powerpc
>
> Disassembly of section .resetvec:
>
> fffffffc <.resetvec>:
> fffc:    4b f8 01 04     b    fff80100 <_start>
> Disassembly of section .text:
>
> fff80000 <version_string-0x4>:
> fff80000:    27 05 19 56     dozi    r24,r5,6486
>
> fff80004 <version_string>:
> fff80004:    50 50 43 42     rlwimi    r16,r2,8,13,1
> fff80008:    6f 6f 74 20     xoris    r15,r27,29728
> fff8000c:    31 2e 31 2e     addic    r9,r14,12590
> fff80010:    35 20 28 4a     addic.    r9,r0,10314
> fff80014:    75 6e 20 20     andis.    r14,r11,8224
> fff80018:    35 20 32 30     addic.    r9,r0,12848
> fff8001c:    30 32 20 2d     addic    r1,r18,8237
>
> [dstrout@dstrout dstrout]$ ~/tools/bin/powerpc-linux-objdump -D vmlinux
> | head -20
>
> vmlinux:     file format elf32-powerpc
>
> Disassembly of section .text:
>
> c0000000 <_start>:
> c0000000:    7c 7f 1b 78     mr    r31,r3
> c0000004:    7c 9e 23 78     mr    r30,r4
> c0000008:    7c bd 2b 78     mr    r29,r5
> c000000c:    7c dc 33 78     mr    r28,r6
> c0000010:    7c fb 3b 78     mr    r27,r7
> c0000014:    3b 00 00 00     li    r24,0
> c0000018:    48 00 23 49     bl    c0002360 <initial_mmu>
>
> c000001c <turn_on_mmu>:
> c000001c:    38 00 10 32     li    r0,4146
> c0000020:    7c 1b 03 a6     mtsrr1    r0
> c0000024:    3c 00 c0 00     lis    r0,-16384
> c0000028:    60 00 22 c0     ori    r0,r0,8896
> c000002c:    7c 1a 03 a6     mtsrr0    r0
>
>
>


** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: Can compile, now on to booting
  2002-06-06  4:06     ` Donald White
@ 2002-06-06 13:00       ` Dave Strout
  0 siblings, 0 replies; 9+ messages in thread
From: Dave Strout @ 2002-06-06 13:00 UTC (permalink / raw)
  To: Donald White; +Cc: linuxppc-embedded


Ahhh -- I was hoping that somebody would have some thoughts like that.
 Could someone send me a copy of vxhack.c ?  The link in the FAQ (
ftp://ftp.mvista.com/pub/Area51/ppc-8xx/vxhack.c  ) doesn't have
anything anymore....

thanks,
dave.


Donald White wrote:

>
> I did this once on a mpc860 board.  It involved running the uncompressed
> kernel image through vxhack.c from Dan Malek with a few fixes since the
> segments seemed to have moved around.  The VxWorks loader would then
> load the hacked image through bootp or tftp.  I also had to have one of
> the Linux bootloader files initialize a bd_t structure.  I was able to
> poke around in memory and find where the VxWorks loader was keeping the
> environment.
>
> Don


** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2002-06-06 13:00 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2002-06-05 17:36 Basics -- what tools for Walnut? Dave Strout
2002-06-05 17:43 ` Mark Hatle
2002-06-05 17:49 ` Frank Rowand
2002-06-05 18:14   ` Dan Malek
2002-06-05 18:24     ` Dave Strout
2002-06-05 19:16 ` Wolfgang Denk
2002-06-05 20:16   ` Can compile, now on to booting Dave Strout
2002-06-06  4:06     ` Donald White
2002-06-06 13:00       ` Dave Strout

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).