Re: Kernel Image Format Issue - Coldfire mcf54418 CPU Failing to Boot

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello Greg,

On 16/05/2024 14:43, Greg Ungerer wrote:
Hi Jean-Michel,

On 15/5/24 21:10, Jean-Michel Hautbois wrote:
Hi Greg,

On 15/05/2024 12:29, Greg Ungerer wrote:
Hi Jean-Michel,


On 15/5/24 17:56, Jean-Michel Hautbois wrote:
Hi Michael,


On 14/05/2024 22:16, Michael Schmitz wrote:
Jean-Michel,

'BIV' is probably a bootinfo tag (Boot Info Version).

Thanks, it helped me, as I read the head.S file and finally progressed :-).

When dumping my vmlinux, I can see the entry point is *not* the load address (it was in the old one):
vmlinux:     file format elf32-m68k


Disassembly of section .text:

40001000 <_stext>:
40001000:    4ef9 4000 2000     jmp 40002000 <_start>
     ...

40002000 <_start>:
40002000:    4e71               nop
40002002:    46fc 2700          movew #9984,%sr
40002006:    203c 0104 0100     movel #17039616,%d0
4000200c:    4e7b 0002          movec %d0,%cacr
40002010:    4e71               nop

Now, when uboot starts the kernel, it is not doing anything (not sure if it hangs or does not display anything on the console. And EARLY_PRINTK is not valid for coldfire :-(. Not sure why, so any guidance here would be appreciate too !

I will now check my platform file but at least I am not trying to execute an instruction "0" :-).

Can you post your kernel .conig file?
Did you just start with your original 3.0.12 config and use that for 6.1.83?

No, I used a very simplified one to start.

CONFIG_NAMESPACES=y
CONFIG_EMBEDDED=y
CONFIG_COLDFIRE=y
CONFIG_M5441x=y
CONFIG_ADVANCED=y
# CONFIG_SINGLE_MEMORY_CHUNK is not set
CONFIG_CLOCK_FREQ=240000000
CONFIG_STMARK2=y
CONFIG_UBOOT=y
CONFIG_RAMBASE=0x40000000
CONFIG_RAMSIZE=0x8000000
CONFIG_VECTORBASE=0x40000000
CONFIG_KERNELBASE=0x40001000
CONFIG_BINFMT_FLAT=y
CONFIG_NET=y
CONFIG_PACKET=y
CONFIG_UNIX=y
CONFIG_INET=y
CONFIG_DEVTMPFS=y
CONFIG_DEVTMPFS_MOUNT=y
CONFIG_NETDEVICES=y
CONFIG_SERIAL_MCF=y
CONFIG_SERIAL_MCF_BAUDRATE=115200
CONFIG_SERIAL_MCF_CONSOLE=y
CONFIG_HID_A4TECH=y
CONFIG_HID_BELKIN=y
CONFIG_HID_CHERRY=y
CONFIG_HID_CYPRESS=y
CONFIG_HID_EZKEY=y
CONFIG_HID_ITE=y
CONFIG_HID_KENSINGTON=y
CONFIG_HID_REDRAGON=y
CONFIG_HID_MICROSOFT=y
CONFIG_HID_MONTEREY=y
CONFIG_VMLINUX_MAP=y
CONFIG_DEBUG_MEMORY_INIT=y
CONFIG_BOOTPARAM=y
CONFIG_BOOTPARAM_STRING="console=ttyS1,115200"

My serial console is on UART6, so I suppose I will have to modify the MCFGPIO_PAR_UART2 register in arch/m68k/coldfire/m5441x.c at the very least.

Was the older 3.0.12 code base a mainline kernel, or is it a modified vendor version?

The kernel came from the Tower system module and it has been adapted to the custom board. I suppose (but it was a long time ago and not me ;-)) that it was a downstream kernel.

https://www.nxp.com/products/no-longer-manufactured/coldfire-mcf5441x-tower-system-module:TWR-MCF5441X

Right now, when load addr is set to 0x40001000 and entry addr is set to 0x40002000 the 6.1 seems to start but nothing is going on my console.

I added a local patch for my uart to be set, but still nothing yet:
diff --git a/arch/m68k/coldfire/m5441x.c b/arch/m68k/coldfire/m5441x.c
index 1e5259a652d1..1bcabef82851 100644
--- a/arch/m68k/coldfire/m5441x.c
+++ b/arch/m68k/coldfire/m5441x.c
@@ -154,8 +154,8 @@ static struct clk * const enable_clks[] __initconst = {
        &__clk_0_23, /* dspi.0 */
        &__clk_0_24, /* uart0 */
        &__clk_0_25, /* uart1 */
-       &__clk_0_26, /* uart2 */
        &__clk_0_27, /* uart3 */
+       &__clk_1_26, /* uart 6 */

        &__clk_0_33, /* pit.1 */
        &__clk_0_37, /* eport */
@@ -171,6 +171,7 @@ static struct clk * const disable_clks[] __initconst = {
        &__clk_0_14, /* i2c.1 */
        &__clk_0_22, /* i2c.0 */
        &__clk_0_23, /* dspi.0 */
+       &__clk_0_26, /* uart2 */
        &__clk_0_28, /* tmr.1 */
        &__clk_0_29, /* tmr.2 */
        &__clk_0_30, /* tmr.2 */
@@ -198,7 +199,6 @@ static struct clk * const disable_clks[] __initconst = {
        &__clk_1_7, /* i2c.5 */
        &__clk_1_24, /* uart 4 */
        &__clk_1_25, /* uart 5 */
-       &__clk_1_26, /* uart 6 */
        &__clk_1_27, /* uart 7 */
        &__clk_1_28, /* uart 8 */
        &__clk_1_29, /* uart 9 */
@@ -234,7 +234,9 @@ static void __init m5441x_uarts_init(void)
 {
        __raw_writeb(0x0f, MCFGPIO_PAR_UART0);
        __raw_writeb(0x00, MCFGPIO_PAR_UART1);
-       __raw_writeb(0x00, MCFGPIO_PAR_UART2);
+       /* TODO: Make it a dedicated file ! */
+       /* UART6 is our console */
+       __raw_writeb(0xaf, MCFGPIO_PAR_UART2);
 }

 static void __init m5441x_fec_init(void)

Thanks !
JM

Regards
Greg


JM


Regards
Greg



Thanks,
JM


Cheers,

     Michael

On 15/05/24 07:11, Jean-Michel Hautbois wrote:
Hello,

I have been on this for a long time now, and I think it is time to ask for some help as the answer might be "easy" :-).

I'm trying to boot an upstream Linux kernel (version 6.1.83 from CIP) on a custom board which already runs an old one (3.0.12).

I'm encountering an issue where the CPU fails to boot with an "Unexpected exception" error when u-boot calls bootm.

-> bootm
## Booting kernel from Legacy Image at 41000000 ...
   Image Name:   Linux-6.1.83-cip18-rt10
   Created:      2024-04-17   5:42:32 UTC
   Image Type:   M68K Linux Kernel Image (uncompressed)
   Data Size:    5684872 Bytes =  5.4 MB
   Load Address: 40001000
   Entry Point:  40001000
   Checksum:  6bc7660a
   Verifying Checksum ... OK
   Loading Kernel Image ... OK
OK


*** Unexpected exception ***
Vector Number: 5  Format: 04  Fault Status: 0

PC: 40001002    SR: 00002700    SP: 4fd5fcdc
D0: 00000000    D1: 00000003    D2: 4fdfa71c    D3: 00000000
D4: 00000000    D5: 00000001    D6: 00000000    D7: 00000001
A0: 00000000    A1: 4fd71494    A2: 40001000    A3: 4fdfa690
A4: 4fd91b30    A5: 4fdf3600    A6: 4fd5fd64

*** Please Reset Board! ***

I tried to use different Load and Entry adress but this is not having any effect.

Sadly, I can't use the (very) old toolchain to build my kernel, and I can't build the old kernel with the toolchain I generated. It has been done with buildroot and I can provide some information if this is relevant.
To summarize:
- It has MMU enabled
- The cpu is passed with -mcpu=54418
- The architecture is passed with -march=isac

As the u-boot version I have can't be updated (at least not easily) I need to provide a uImage, so I call mkimage for this when the vmlinux file is generated.

I've compared the kernel image format with an older working kernel image, and it seems the issue is related to the kernel image format.

```
$> hexdump -C uImage-3.0.12 |head
00000000  27 05 19 56 c6 4d 40 59  62 ac 6a be 00 2f a2 00 |'..V.M@Yb.j../..| 00000010  40 02 00 00 40 02 00 00  74 e8 ca f4 05 0c 02 00 |@...@...t.......| 00000020  4c 69 6e 75 78 2d 33 2e  30 2e 31 32 2d 72 74 33 |Linux-3.0.12-rt3| 00000030  33 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00 |3...............| 00000040  60 08 42 49 56 1a 00 00  00 00 4e f9 40 30 20 00 |`.BIV.....N.@0 .| 00000050  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00 |................|
*
00001040  4e f9 40 30 20 00 4e 56  00 00 9f fc 00 00 00 04  |N.@0 .NV........| 00001050  48 d7 00 01 20 2f 00 0c  4e 7b 00 03 4c d7 00 01  |H... /..N{..L...| 00001060  df fc 00 00 00 04 4e 5e  4e 75 00 00 4e 75 4e 75 |......N^Nu..NuNu|
```

```
hexdump -C output/images/uImage |head
00000000  27 05 19 56 ab 1d 06 74  66 1f 61 48 00 56 be 88 |'..V...tf.aH.V..| 00000010  40 00 10 00 40 00 10 00  6b c7 66 0a 05 0c 02 00 |@...@...k.f.....| 00000020  4c 69 6e 75 78 2d 36 2e  31 2e 38 33 2d 63 69 70 |Linux-6.1.83-cip| 00000030  31 38 2d 72 74 31 30 00  00 00 00 00 00 00 00 00 |18-rt10.........| 00000040  7f 45 4c 46 01 02 01 00  00 00 00 00 00 00 00 00 |.ELF............| 00000050  00 02 00 04 00 00 00 01  40 00 20 00 00 00 00 34 |........@. ....4| 00000060  00 56 bb b8 00 00 00 26  00 34 00 20 00 04 00 28 |.V.....&.4. ...(| 00000070  00 12 00 11 00 00 00 01  00 00 00 00 40 00 00 00 |............@...| 00000080  40 00 00 00 00 39 d3 d0  00 39 d3 d0 00 00 00 05 |@....9...9......| 00000090  00 00 20 00 00 00 00 01  00 39 e0 00 40 39 e0 00  |.. ......9..@9..|
```

I am a bit surprised by the information at offset 0x40. My kernel is an ELF file, but the old one is a BIV file I don't even know what it can be -_- !

I'm happy to provide any additional information or details that might be helpful in resolving this issue.

Thanks in advance for any help !
JM









[Index of Archives]     [Video for Linux]     [Yosemite News]     [Linux S/390]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux