SDRAM weirdness.
Hyun-Joon Cha
tachyon at postech.ac.kr
Fri Sep 1 02:18:09 EST 2000
Hello all.
My board uses SAMSUNG K4S643232C SDRAM and it's configuration is 512K x 32bit x 4 banks, 11 rows and 8 column.
The Board quipped 2 SDRAMs (total 16MB) and each uses CS2 and CS3.
MPC to SDRAM pin configuration is as below.
MPC SDRAM
========================
A29 A0
A28 A1
A27 A2
A26 A3
A25 A4
A24 A5
A23 A6
A22 A7
A21 A8
A20 A9
GPL_A0 A10
A9 BA0
A8 BA1
OE_GPL_A1 RAS
GPL_A2 CAS
GPL_A3 WE
The problem is that when I write a word to some location then it will appear another location like a mirror.
The example symptom is - I'm using a BDI2000 for BDM, md is mem. disp. and mm is mem. modify -
BDI>md 0x0 5
00000000 : 0xffffffff - 1 ....
00000004 : 0xffffffff - 1 ....
00000008 : 0xffffffff - 1 ....
0000000c : 0xffffffff - 1 ....
00000010 : 0xffffffff - 1 ....
BDI>md 0x100000 5
00100000 : 0xffffffff - 1 ....
00100004 : 0xffffffff - 1 ....
00100008 : 0xffffffff - 1 ....
0010000c : 0xffffffff - 1 ....
00100010 : 0xffffffff - 1 ....
BDI>mm 0x0 0x0
BDI>md 0x0 5
00000000 : 0x00000000 0 ....
00000004 : 0xffffffff - 1 ....
00000008 : 0xffffffff - 1 ....
0000000c : 0xffffffff - 1 ....
00000010 : 0xffffffff - 1 ....
BDI>md 0x100000 5
00100000 : 0x00000000 0 ....
00100004 : 0xffffffff - 1 ....
00100008 : 0xffffffff - 1 ....
0010000c : 0xffffffff - 1 ....
00100010 : 0xffffffff - 1 ....
BDI>
As you can see, mem[addr]=data means mem[addr + 0x100000]=data.
So, I've made some program to find duplicated memory area and the result is that
Memory content of left area is equal to right
==============================================
0x0 ~ 0xfffff eq. 0x100000 ~ 0x1fffff
0x200000 ~ 0x2fffff eq. 0x300000 ~ 0x3fffff
0x400000 ~ 0x4fffff eq. 0x500000 ~ 0x5fffff
0x600000 ~ 0x6fffff eq. 0x700000 ~ 0x7fffff
0x800000 ~ 0x8fffff eq. 0x900000 ~ 0x9fffff
0xa00000 ~ 0xafffff eq. 0xb00000 ~ 0xbfffff
0xc00000 ~ 0xcfffff eq. 0xd00000 ~ 0xdfffff
0xe00000 ~ 0xefffff eq. 0xf00000 ~ 0xffffff
How can I solve this?
What is the point of it? The UPM table? BR, OR values? MAMR value? SDRAM init. sequence? or HW related? I couldn't find any clue of it.
Please help me.
My register configuration for BDI2000 follows. Test program has same register values.
; bdiGDB configuration file for 850 v.2 board
; -------------------------------------------
;
[INIT]
; init core register
WSPR 149 0x0082000F ;DER : for debug MMU
WSPR 638 0xFF000000 ;IMMR
WSPR 158 0x00000007 ;ICTRL:
WSPR 796 0x00000000 ;M_TWB: invalidate TWB
; init SIU register
WM32 0xFF000000 0x01E10940 ;SIUMCR
WM32 0xFF000004 0xFFFFFF88 ;SYPCR
WM16 0xFF000200 0x0001 ;TBSCR
WM16 0xFF000240 0x0002 ;PISCR
WM32 0xFF000284 0x0000D000 ;PLPRCR set clock to 25MHz
; init UPM for Samsung KS4S643232C_2Mx32 SDRAM
SUPM 0xFF000168 0xFF00017c ;set address for MCR and MDR
WUPM 0x00000000 0x1F07FC04 ;UPMA single read
WUPM 0x00000001 0xEEAEFC04
WUPM 0x00000002 0x11ADFC04
WUPM 0x00000004 0x1FF77C47
WUPM 0x00000005 0x1FF77C34
WUPM 0x00000006 0xEFEABC34
WUPM 0x00000007 0x1FB57C35 ;last
WUPM 0x00000008 0x1F07FC04 ;UPMA burst read
WUPM 0x00000009 0xEEAEFC04
WUPM 0x0000000A 0x10ADFC04
WUPM 0x0000000B 0xF0AFFC00
WUPM 0x0000000C 0xF0AFFC00
WUPM 0x0000000D 0xF1AFFC00
WUPM 0x0000000E 0xEFBBBC00
WUPM 0x0000000F 0x1FF77C47 ;last
WUPM 0x00000010 0xFFFFFFFF
WUPM 0x00000011 0xFFFFFFFF
WUPM 0x00000012 0xFFFFFFFF
WUPM 0x00000013 0xFFFFFFFF
WUPM 0x00000014 0xFFFFFFFF
WUPM 0x00000015 0xFFFFFFFF
WUPM 0x00000016 0xFFFFFFFF
WUPM 0x00000017 0xFFFFFFFF
WUPM 0x00000018 0x1F27FC04 ;UPMA single write
WUPM 0x00000019 0xEEAEBC00
WUPM 0x0000001A 0x01B93C04
WUPM 0x0000001B 0x1FF77C47 ;last
WUPM 0x0000001C 0xFFFFFFFF
WUPM 0x0000001D 0xFFFFFFFF
WUPM 0x0000001E 0xFFFFFFFF
WUPM 0x0000001F 0xFFFFFFFF
WUPM 0x00000020 0x1F07FC04 ;UPMA burst write
WUPM 0x00000021 0xEEAEBC00
WUPM 0x00000022 0x10AD7C00
WUPM 0x00000023 0xF0AFFC00
WUPM 0x00000024 0xF0AFFC00
WUPM 0x00000025 0xE1BBBC04
WUPM 0x00000026 0x1FF77C47 ;last
WUPM 0x00000027 0xFFFFFFFF
WUPM 0x00000028 0xFFFFFFFF
WUPM 0x00000029 0xFFFFFFFF
WUPM 0x0000002A 0xFFFFFFFF
WUPM 0x0000002B 0xFFFFFFFF
WUPM 0x0000002C 0xFFFFFFFF
WUPM 0x0000002D 0xFFFFFFFF
WUPM 0x0000002E 0xFFFFFFFF
WUPM 0x0000002F 0xFFFFFFFF
WUPM 0x00000030 0x1FF5FC84 ;UPMA refresh
WUPM 0x00000031 0xFFFFFC04
WUPM 0x00000032 0xFFFFFC04
WUPM 0x00000033 0xFFFFFC04
WUPM 0x00000034 0xFFFFFC84
WUPM 0x00000035 0xFFFFFC07
WUPM 0x00000036 0xFFFFFFFF
WUPM 0x00000037 0xFFFFFFFF
WUPM 0x00000038 0xFFFFFFFF
WUPM 0x00000039 0xFFFFFFFF
WUPM 0x0000003A 0xFFFFFFFF
WUPM 0x0000003B 0xFFFFFFFF ;last
WUPM 0x0000003C 0x7FFFFC07 ;UPMA exception ;last
WUPM 0x0000003D 0xFFFFFFFF
WUPM 0x0000003E 0xFFFFFFFF
WUPM 0x0000003F 0xFFFFFFFF
; init memory controller
WM32 0xFF000100 0xFFD20401 ;BR0 8bit!
WM32 0xFF000104 0xFFC00160 ;OR0
WM32 0xFF000114 0xFF800A00 ;OR2
WM32 0xFF000110 0x00000081 ;BR2
WM32 0xFF00011C 0xFF800A00 ;OR3
WM32 0xFF000118 0x00800081 ;BR3
WM16 0xFF00017A 0x0400 ;MPTPR
WM32 0xFF000170 0x18804114 ;MAMR, loop time is 4
; start sdram init
WM32 0xFF000168 0x80004105 ;MCR for CS2, precharge
WM32 0xFF000168 0x80006105 ;MCR for CS3, precharge
WM32 0xFF000170 0x18804118 ;MAMR, loop time is 8
WM32 0xFF000168 0x80004130 ;MCR for CS2, run refresh
WM32 0xFF000168 0x80006130 ;MCR for CS3, run refresh
WM32 0xFF000164 0x88 ;MAR
WM32 0xFF000168 0x80004106 ;MCR for CS2, run MRS
WM32 0xFF000168 0x80006106 ;MCR for CS3, run MRS
WM32 0xFF000170 0x18804114 ;MAMR, loop time is 4
WM32 0xFF000284 0x0010D000 ;PLPRCR set clock to 50MHz
... sniffed host, flash settings.
------------------------------------------------------------------
Thanks in advance.
Have a nice day.
** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/
More information about the Linuxppc-embedded
mailing list