* [U-Boot-Users] Problem with cache diag on sequoia board in PPC4xx branch for-1.3.2
@ 2007-12-20 22:31 Larry Johnson
2007-12-22 7:56 ` Stefan Roese
0 siblings, 1 reply; 4+ messages in thread
From: Larry Johnson @ 2007-12-20 22:31 UTC (permalink / raw)
To: u-boot
Hi Stefan,
In testing my merge of Korat PPC440EPx board support into PPC4xx branch
"for-1.3.2", I found problem with the "DIAG RUN CACHE" command. The
same problem occurs in the latest for-1.3.2 code for sequoia. Here is a
copy of the console output showing what happens:
=> diag run cache
Bad trap at PC: ff70220, SR: 21000, vector=1300
NIP: 0FF70220 XER: 2000005F LR: 0FF702D4 REGS: 0ff17870 TRAP: 1300 DEAR: 10000000
MSR: 00021000 EE: 0 PR: 0 FP: 0 ME: 1 IR/DR: 00
GPR00: 0000003F 0FF17960 7FFFFFFF 10000000 00000400 00000400 00000020 FFFFFFFF
GPR08: 0FFFBFEC 0FF6F888 0000000C 10000000 00000400 00000000 0FFABD00 0FFBA000
GPR16: 15809012 22406001 C1904012 0FF17B6A 00000001 00000000 0FF17C65 00000000
GPR24: 00000600 0000000C 00000000 00000001 0FFA6AE8 0FF17F34 0FFAC714 0FF6F7DC
Call backtrace:
0FF17A44 0FF6B0E8 0FF6B4AC 0FF734D0 0FF71270 0FF71450 0FF5ECA4
0FF5C6B8 F1FFFFFF
Exception
U-Boot 1.3.1-g76ace773 (Dec 20 2007 - 17:07:17)
CPU: AMCC PowerPC 440EPx Rev. A at 528 MHz (PLB=132, OPB=66, EBC=66 MHz)
Security/Kasumi support
Bootstrap Option H - Boot ROM Location I2C (Addr 0x52)
Internal PCI arbiter enabled, PCI async ext clock used
32 kB I-Cache 32 kB D-Cache
Board: Sequoia - AMCC PPC440EPx Evaluation Board, Rev. F, PCI=33 MHz, serial# 52149
I2C: ready
DTT: 1 is 24 C
DRAM: 256 MB
FLASH: 64 MB
NAND: 32 MiB
PCI: Bus Dev VenId DevId Class Int
In: serial
Out: serial
Err: serial
USB: Host(int phy) Device(ext phy)
Net: ppc_4xx_eth0, ppc_4xx_eth1
Type "run flash_nfs" to mount root filesystem over NFS
=>
This problem does not occur on sequoia using the latest mainline (i.e.,
master branch) code from the PPC4xx repository.
Just thought you'd like to know. :-)
Best regards,
Larry
^ permalink raw reply [flat|nested] 4+ messages in thread* [U-Boot-Users] Problem with cache diag on sequoia board in PPC4xx branch for-1.3.2 2007-12-20 22:31 [U-Boot-Users] Problem with cache diag on sequoia board in PPC4xx branch for-1.3.2 Larry Johnson @ 2007-12-22 7:56 ` Stefan Roese 2007-12-22 11:23 ` Stefan Roese 0 siblings, 1 reply; 4+ messages in thread From: Stefan Roese @ 2007-12-22 7:56 UTC (permalink / raw) To: u-boot Hi Larry, On Thursday 20 December 2007, Larry Johnson wrote: > In testing my merge of Korat PPC440EPx board support into PPC4xx branch > "for-1.3.2", I found problem with the "DIAG RUN CACHE" command. The > same problem occurs in the latest for-1.3.2 code for sequoia. Here is a > copy of the console output showing what happens: Thanks for reporting. I'll try to take a look at it in the next days. But I have no problems at all, if you provide a patch to fix it. ;) Best regards, Stefan ===================================================================== DENX Software Engineering GmbH, MD: Wolfgang Denk & Detlev Zundel HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany Phone: +49-8142-66989-0 Fax: +49-8142-66989-80 Email: office at denx.de ===================================================================== ^ permalink raw reply [flat|nested] 4+ messages in thread
* [U-Boot-Users] Problem with cache diag on sequoia board in PPC4xx branch for-1.3.2 2007-12-22 7:56 ` Stefan Roese @ 2007-12-22 11:23 ` Stefan Roese 2007-12-22 19:38 ` Larry Johnson 0 siblings, 1 reply; 4+ messages in thread From: Stefan Roese @ 2007-12-22 11:23 UTC (permalink / raw) To: u-boot On Saturday 22 December 2007, Stefan Roese wrote: > > In testing my merge of Korat PPC440EPx board support into PPC4xx branch > > "for-1.3.2", I found problem with the "DIAG RUN CACHE" command. The > > same problem occurs in the latest for-1.3.2 code for sequoia. Here is a > > copy of the console output showing what happens: > > Thanks for reporting. I'll try to take a look at it in the next days. But I > have no problems at all, if you provide a patch to fix it. ;) OK, I found the problem and fixed in the for-1.3.2 branch: commit 8092791c5d959e89f9bc4ed0ff880c3509da743f Author: Stefan Roese <sr@denx.de> Date: Sat Dec 22 12:18:26 2007 +0100 ppc4xx: Fix problem in 44x cache POST routine As repoted by Larry Johnson, running "diag run cache" caused a crash in U-Boot. This problem was introduced by a patch that removed the TLB entry for the cache test after the test has completed. Since this TLB was only setup once, a 2nd attempt to run this cache test failed with a crash. Now this TLB entry is created every time the routine is called. Signed-off-by: Stefan Roese <sr@denx.de> diff --git a/post/cpu/ppc4xx/cache.c b/post/cpu/ppc4xx/cache.c index 30d5088..c8ddf35 100644 --- a/post/cpu/ppc4xx/cache.c +++ b/post/cpu/ppc4xx/cache.c @@ -51,8 +51,6 @@ int cache_post_test4 (int tlb, void *p, int size); int cache_post_test5 (int tlb, void *p, int size); int cache_post_test6 (int tlb, void *p, int size); -static int tlb = -1; /* index to the victim TLB entry */ - #ifdef CONFIG_440 static unsigned char testarea[CACHE_POST_SIZE] __attribute__((__aligned__(CACHE_POST_SIZE))); @@ -60,7 +58,7 @@ __attribute__((__aligned__(CACHE_POST_SIZE))); int cache_post_test (int flags) { - void* virt = (void*)CFG_POST_CACHE_ADDR; + void *virt = (void *)CFG_POST_CACHE_ADDR; int ints; int res = 0; @@ -72,26 +70,25 @@ int cache_post_test (int flags) */ #ifdef CONFIG_440 int word0, i; + int tlb; /* index to the victim TLB entry */ - if (tlb < 0) { - /* - * Allocate a new TLB entry, since we are going to modify - * the write-through and caching inhibited storage attributes. - */ - program_tlb((u32)testarea, (u32)virt, - CACHE_POST_SIZE, TLB_WORD2_I_ENABLE); - - /* Find the TLB entry */ - for (i = 0;; i++) { - if (i >= PPC4XX_TLB_SIZE) { - printf ("Failed to program tlb entry\n"); - return -1; - } - word0 = mftlb1(i); - if (TLB_WORD0_EPN_DECODE(word0) == (u32)virt) { - tlb = i; - break; - } + /* + * Allocate a new TLB entry, since we are going to modify + * the write-through and caching inhibited storage attributes. + */ + program_tlb((u32)testarea, (u32)virt, CACHE_POST_SIZE, + TLB_WORD2_I_ENABLE); + + /* Find the TLB entry */ + for (i = 0;; i++) { + if (i >= PPC4XX_TLB_SIZE) { + printf ("Failed to program tlb entry\n"); + return -1; + } + word0 = mftlb1(i); + if (TLB_WORD0_EPN_DECODE(word0) == (u32)virt) { + tlb = i; + break; } } #endif ^ permalink raw reply related [flat|nested] 4+ messages in thread
* [U-Boot-Users] Problem with cache diag on sequoia board in PPC4xx branch for-1.3.2 2007-12-22 11:23 ` Stefan Roese @ 2007-12-22 19:38 ` Larry Johnson 0 siblings, 0 replies; 4+ messages in thread From: Larry Johnson @ 2007-12-22 19:38 UTC (permalink / raw) To: u-boot Stefan Roese wrote: > On Saturday 22 December 2007, Stefan Roese wrote: >>> In testing my merge of Korat PPC440EPx board support into PPC4xx branch >>> "for-1.3.2", I found problem with the "DIAG RUN CACHE" command. The >>> same problem occurs in the latest for-1.3.2 code for sequoia. Here is a >>> copy of the console output showing what happens: >> Thanks for reporting. I'll try to take a look at it in the next days. But I >> have no problems at all, if you provide a patch to fix it. ;) > > OK, I found the problem and fixed in the for-1.3.2 branch: > > commit 8092791c5d959e89f9bc4ed0ff880c3509da743f > Author: Stefan Roese <sr@denx.de> > Date: Sat Dec 22 12:18:26 2007 +0100 > > ppc4xx: Fix problem in 44x cache POST routine > > As repoted by Larry Johnson, running "diag run cache" caused a crash > in U-Boot. This problem was introduced by a patch that removed the > TLB entry for the cache test after the test has completed. Since this > TLB was only setup once, a 2nd attempt to run this cache test > failed with a crash. Now this TLB entry is created every time the > routine is called. > > Signed-off-by: Stefan Roese <sr@denx.de> > > [snip] This fixes the problem on Korat as well. Thanks! Best regards, Larry ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2007-12-22 19:38 UTC | newest] Thread overview: 4+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2007-12-20 22:31 [U-Boot-Users] Problem with cache diag on sequoia board in PPC4xx branch for-1.3.2 Larry Johnson 2007-12-22 7:56 ` Stefan Roese 2007-12-22 11:23 ` Stefan Roese 2007-12-22 19:38 ` Larry Johnson
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox