1menuconfig ELBC_BR1_OR1
2	bool "ELBC BR1/OR1"
3
4if ELBC_BR1_OR1
5
6config BR1_OR1_NAME
7	string "Identifier"
8
9config BR1_OR1_BASE
10	hex "Port base"
11
12choice
13	prompt "Port size"
14
15config BR1_PORTSIZE_8BIT
16	bool "8-bit"
17
18config BR1_PORTSIZE_16BIT
19	depends on !BR1_MACHINE_FCM
20	bool "16-bit"
21
22
23config BR1_PORTSIZE_32BIT
24	depends on !BR1_MACHINE_FCM
25	depends on ARCH_MPC8349 || ARCH_MPC8360 || ARCH_MPC8379
26	bool "32-bit"
27
28endchoice
29
30if BR1_MACHINE_FCM
31
32choice
33	prompt "Data Error Checking"
34
35config BR1_ERRORCHECKING_DISABLED
36	bool "Disabled"
37
38config BR1_ERRORCHECKING_ECC_CHECKING
39	bool "ECC checking / No ECC generation"
40
41config BR1_ERRORCHECKING_BOTH
42	bool "ECC checking and generation"
43
44endchoice
45
46endif
47
48config BR1_WRITE_PROTECT
49	bool "Write-protect"
50
51config BR1_MACHINE_UPM
52	bool
53
54choice
55	prompt "Machine select"
56
57config BR1_MACHINE_GPCM
58	bool "GPCM"
59
60config BR1_MACHINE_FCM
61	depends on !ARCH_MPC832X && !ARCH_MPC8349 && !ARCH_MPC8360
62	bool "FCM"
63
64config BR1_MACHINE_SDRAM
65	depends on ARCH_MPC8349 || ARCH_MPC8360
66	bool "SDRAM"
67
68config BR1_MACHINE_UPMA
69	select BR1_MACHINE_UPM
70	bool "UPM (A)"
71
72config BR1_MACHINE_UPMB
73	select BR1_MACHINE_UPM
74	bool "UPM (B)"
75
76config BR1_MACHINE_UPMC
77	select BR1_MACHINE_UPM
78	bool "UPM (C)"
79
80endchoice
81
82if ARCH_MPC8313 || ARCH_MPC8323 || ARCH_MPC8360
83
84choice
85	prompt "Atomic operations"
86
87config BR1_ATOMIC_NONE
88	bool "No atomic operations"
89
90config BR1_ATOMIC_RAWA
91	bool "Read-after-write-atomic"
92
93config BR1_ATOMIC_WARA
94	bool "Write-after-read-atomic"
95
96endchoice
97
98endif
99
100if BR1_MACHINE_GPCM || BR1_MACHINE_FCM || BR1_MACHINE_UPM || BR1_MACHINE_SDRAM
101
102choice
103	prompt "Address mask"
104
105config OR1_AM_32_KBYTES
106	depends on !BR1_MACHINE_SDRAM
107	bool "32 kb"
108
109config OR1_AM_64_KBYTES
110	bool "64 kb"
111
112config OR1_AM_128_KBYTES
113	bool "128 kb"
114
115config OR1_AM_256_KBYTES
116	bool "256 kb"
117
118config OR1_AM_512_KBYTES
119	bool "512 kb"
120
121config OR1_AM_1_MBYTES
122	bool "1 mb"
123
124config OR1_AM_2_MBYTES
125	bool "2 mb"
126
127config OR1_AM_4_MBYTES
128	bool "4 mb"
129
130config OR1_AM_8_MBYTES
131	bool "8 mb"
132
133config OR1_AM_16_MBYTES
134	bool "16 mb"
135
136config OR1_AM_32_MBYTES
137	bool "32 mb"
138
139config OR1_AM_64_MBYTES
140	bool "64 mb"
141
142# XXX: Some boards define 128MB AM with GPCM, even though it should not be
143# possible according to the manuals
144config OR1_AM_128_MBYTES
145	bool "128 mb"
146
147# XXX: Some boards define 256MB AM with GPCM, even though it should not be
148# possible according to the manuals
149config OR1_AM_256_MBYTES
150	bool "256 mb"
151
152config OR1_AM_512_MBYTES
153	depends on BR1_MACHINE_FCM
154	bool "512 mb"
155
156# XXX: Some boards define 1GB AM with GPCM, even though it should not be
157# possible according to the manuals
158config OR1_AM_1_GBYTES
159	bool "1 gb"
160
161config OR1_AM_2_GBYTES
162	depends on BR1_MACHINE_FCM
163	bool "2 gb"
164
165config OR1_AM_4_GBYTES
166	depends on BR1_MACHINE_FCM
167	bool "4 gb"
168
169endchoice
170
171config OR1_XAM_SET
172	bool "Set unused bytes after address mask"
173choice
174	prompt "Buffer control disable"
175
176config OR1_BCTLD_ASSERTED
177	bool "Asserted"
178
179config OR1_BCTLD_NOT_ASSERTED
180	bool "Not asserted"
181
182endchoice
183
184endif
185
186if BR1_MACHINE_GPCM || BR1_MACHINE_FCM
187
188choice
189	prompt "Cycle length in bus clocks"
190
191config OR1_SCY_0
192	bool "No wait states"
193
194config OR1_SCY_1
195	bool "1 wait state"
196
197config OR1_SCY_2
198	bool "2 wait states"
199
200config OR1_SCY_3
201	bool "3 wait states"
202
203config OR1_SCY_4
204	bool "4 wait states"
205
206config OR1_SCY_5
207	bool "5 wait states"
208
209config OR1_SCY_6
210	bool "6 wait states"
211
212config OR1_SCY_7
213	bool "7 wait states"
214
215config OR1_SCY_8
216	depends on BR1_MACHINE_GPCM
217	bool "8 wait states"
218
219config OR1_SCY_9
220	depends on BR1_MACHINE_GPCM
221	bool "9 wait states"
222
223config OR1_SCY_10
224	depends on BR1_MACHINE_GPCM
225	bool "10 wait states"
226
227config OR1_SCY_11
228	depends on BR1_MACHINE_GPCM
229	bool "11 wait states"
230
231config OR1_SCY_12
232	depends on BR1_MACHINE_GPCM
233	bool "12 wait states"
234
235config OR1_SCY_13
236	depends on BR1_MACHINE_GPCM
237	bool "13 wait states"
238
239config OR1_SCY_14
240	depends on BR1_MACHINE_GPCM
241	bool "14 wait states"
242
243config OR1_SCY_15
244	depends on BR1_MACHINE_GPCM
245	bool "15 wait states"
246
247endchoice
248
249endif # BR1_MACHINE_GPCM || BR1_MACHINE_FCM
250
251if BR1_MACHINE_GPCM
252
253choice
254	prompt "Chip select negotiation time"
255
256config OR1_CSNT_NORMAL
257	bool "Normal"
258
259config OR1_CSNT_EARLIER
260	bool "Earlier"
261
262endchoice
263
264choice
265	prompt "Address to chip-select setup"
266
267config OR1_ACS_SAME_TIME
268	bool "At the same time"
269
270config OR1_ACS_HALF_CYCLE_EARLIER
271	bool "Half of a bus clock cycle earlier"
272
273config OR1_ACS_QUARTER_CYCLE_EARLIER
274	bool "Half/Quarter of a bus clock cycle earlier"
275
276endchoice
277
278choice
279	prompt "Extra address to check-select setup"
280
281config OR1_XACS_NORMAL
282	bool "Normal"
283
284config OR1_XACS_EXTENDED
285	bool "Extended"
286
287endchoice
288
289choice
290	prompt "External address termination"
291
292config OR1_SETA_INTERNAL
293	bool "Access is terminated internally"
294
295config OR1_SETA_EXTERNAL
296	bool "Access is terminated externally"
297
298endchoice
299
300endif # BR1_MACHINE_GPCM
301
302if BR1_MACHINE_FCM
303
304choice
305	prompt "NAND Flash EEPROM page size"
306
307config OR1_PGS_SMALL
308	bool "Small page device"
309
310config OR1_PGS_LARGE
311	bool "Large page device"
312
313endchoice
314
315choice
316	prompt "Chip select to command time"
317
318config OR1_CSCT_1_CYCLE
319	depends on OR1_TRLX_NORMAL
320	bool "1 cycle"
321
322config OR1_CSCT_2_CYCLE
323	depends on OR1_TRLX_RELAXED
324	bool "2 cycles"
325
326config OR1_CSCT_4_CYCLE
327	depends on OR1_TRLX_NORMAL
328	bool "4 cycles"
329
330config OR1_CSCT_8_CYCLE
331	depends on OR1_TRLX_RELAXED
332	bool "8 cycles"
333
334endchoice
335
336choice
337	prompt "Command setup time"
338
339config OR1_CST_COINCIDENT
340	depends on OR1_TRLX_NORMAL
341	bool "Coincident with any command"
342
343config OR1_CST_QUARTER_CLOCK
344	depends on OR1_TRLX_NORMAL
345	bool "0.25 clocks after"
346
347config OR1_CST_HALF_CLOCK
348	depends on OR1_TRLX_RELAXED
349	bool "0.5 clocks after"
350
351config OR1_CST_ONE_CLOCK
352	depends on OR1_TRLX_RELAXED
353	bool "1 clock after"
354
355endchoice
356
357choice
358	prompt "Command hold time"
359
360config OR1_CHT_HALF_CLOCK
361	depends on OR1_TRLX_NORMAL
362	bool "0.5 clocks before"
363
364config OR1_CHT_ONE_CLOCK
365	depends on OR1_TRLX_NORMAL
366	bool "1 clock before"
367
368config OR1_CHT_ONE_HALF_CLOCK
369	depends on OR1_TRLX_RELAXED
370	bool "1.5 clocks before"
371
372config OR1_CHT_TWO_CLOCK
373	depends on OR1_TRLX_RELAXED
374	bool "2 clocks before"
375
376endchoice
377
378choice
379	prompt "Reset setup time"
380
381config OR1_RST_THREE_QUARTER_CLOCK
382	depends on OR1_TRLX_NORMAL
383	bool "0.75 clocks prior"
384
385config OR1_RST_ONE_HALF_CLOCK
386	depends on OR1_TRLX_RELAXED
387	bool "0.5 clocks prior"
388
389config OR1_RST_ONE_CLOCK
390	bool "1 clock prior"
391
392endchoice
393
394endif # BR1_MACHINE_FCM
395
396if BR1_MACHINE_UPM
397
398choice
399	prompt "Burst inhibit"
400
401config OR1_BI_BURSTSUPPORT
402	bool "Support burst access"
403
404config OR1_BI_BURSTINHIBIT
405	bool "Inhibit burst access"
406
407endchoice
408
409endif # BR1_MACHINE_UPM
410
411if BR1_MACHINE_SDRAM
412
413choice
414	prompt "Number of column address lines"
415
416config OR1_COLS_7
417	bool "7"
418
419config OR1_COLS_8
420	bool "8"
421
422config OR1_COLS_9
423	bool "9"
424
425config OR1_COLS_10
426	bool "10"
427
428config OR1_COLS_11
429	bool "11"
430
431config OR1_COLS_12
432	bool "12"
433
434config OR1_COLS_13
435	bool "13"
436
437config OR1_COLS_14
438	bool "14"
439
440endchoice
441
442choice
443	prompt "Number of rows address lines"
444
445config OR1_ROWS_9
446	bool "9"
447
448config OR1_ROWS_10
449	bool "10"
450
451config OR1_ROWS_11
452	bool "11"
453
454config OR1_ROWS_12
455	bool "12"
456
457config OR1_ROWS_13
458	bool "13"
459
460config OR1_ROWS_14
461	bool "14"
462
463config OR1_ROWS_15
464	bool "15"
465
466endchoice
467
468choice
469	prompt "Page mode select"
470
471config OR1_PMSEL_BTB
472	bool "Back-to-back"
473
474config OR1_PMSEL_KEPT_OPEN
475	bool "Page kept open until page miss or refresh"
476
477endchoice
478
479endif # BR1_MACHINE_SDRAM
480
481choice
482	prompt "Relaxed timing"
483
484config OR1_TRLX_NORMAL
485	bool "Normal"
486
487config OR1_TRLX_RELAXED
488	bool "Relaxed"
489
490endchoice
491
492choice
493	prompt "Extended hold time"
494
495config OR1_EHTR_NORMAL
496	depends on OR1_TRLX_NORMAL
497	bool "Normal"
498
499config OR1_EHTR_1_CYCLE
500	depends on OR1_TRLX_NORMAL
501	bool "1 idle clock cycle inserted"
502
503config OR1_EHTR_4_CYCLE
504	depends on OR1_TRLX_RELAXED
505	bool "4 idle clock cycles inserted"
506
507config OR1_EHTR_8_CYCLE
508	depends on OR1_TRLX_RELAXED
509	bool "8 idle clock cycles inserted"
510
511endchoice
512
513if !ARCH_MPC8308
514
515choice
516	prompt "External address latch delay"
517
518config OR1_EAD_NONE
519	bool "None"
520
521config OR1_EAD_EXTRA
522	bool "Extra"
523
524endchoice
525
526endif # !ARCH_MPC8308
527
528endif # ELBC_BR1_OR1
529
530config BR1_PORTSIZE
531	hex
532	default 0x800 if BR1_PORTSIZE_8BIT
533	default 0x1000 if BR1_PORTSIZE_16BIT
534	default 0x1800 if BR1_PORTSIZE_32BIT
535
536config BR1_ERRORCHECKING
537	hex
538	default 0x0 if !BR1_MACHINE_FCM
539	default 0x0 if BR1_ERRORCHECKING_DISABLED
540	default 0x200 if BR1_ERRORCHECKING_ECC_CHECKING
541	default 0x400 if BR1_ERRORCHECKING_BOTH
542
543config BR1_WRITE_PROTECT_BIT
544	hex
545	default 0x0 if !BR1_WRITE_PROTECT
546	default 0x100 if BR1_WRITE_PROTECT
547
548config BR1_MACHINE
549	hex
550	default 0x0 if BR1_MACHINE_GPCM
551	default 0x20 if BR1_MACHINE_FCM
552	default 0x60 if BR1_MACHINE_SDRAM
553	default 0x80 if BR1_MACHINE_UPMA
554	default 0xa0 if BR1_MACHINE_UPMB
555	default 0xc0 if BR1_MACHINE_UPMC
556
557config BR1_ATOMIC
558	hex
559	default 0x0 if !ARCH_MPC8313 && !ARCH_MPC8323 && !ARCH_MPC8360
560	default 0x0 if BR1_ATOMIC_NONE
561	default 0x4 if BR1_ATOMIC_RAWA
562	default 0x8 if BR1_ATOMIC_WARA
563
564config BR1_VALID_BIT
565	hex
566	default 0x0 if !ELBC_BR1_OR1
567	default 0x1 if ELBC_BR1_OR1
568
569config OR1_AM
570	hex
571	default 0xffff8000 if OR1_AM_32_KBYTES && !BR1_MACHINE_SDRAM
572	default 0xffff0000 if OR1_AM_64_KBYTES
573	default 0xfffe0000 if OR1_AM_128_KBYTES
574	default 0xfffc0000 if OR1_AM_256_KBYTES
575	default 0xfff80000 if OR1_AM_512_KBYTES
576	default 0xfff00000 if OR1_AM_1_MBYTES
577	default 0xffe00000 if OR1_AM_2_MBYTES
578	default 0xffc00000 if OR1_AM_4_MBYTES
579	default 0xff800000 if OR1_AM_8_MBYTES
580	default 0xff000000 if OR1_AM_16_MBYTES
581	default 0xfe000000 if OR1_AM_32_MBYTES
582	default 0xfc000000 if OR1_AM_64_MBYTES
583	default 0xf8000000 if OR1_AM_128_MBYTES
584	default 0xf0000000 if OR1_AM_256_MBYTES
585	default 0xe0000000 if OR1_AM_512_MBYTES
586	default 0xc0000000 if OR1_AM_1_GBYTES
587	default 0x80000000 if OR1_AM_2_GBYTES
588	default 0x00000000 if OR1_AM_4_GBYTES
589
590config OR1_XAM
591	hex
592	default 0x0 if !OR1_XAM_SET
593	default 0x6000 if OR1_XAM_SET
594
595config OR1_BCTLD
596	hex
597	default 0x0 if OR1_BCTLD_ASSERTED
598	default 0x1000 if OR1_BCTLD_NOT_ASSERTED
599
600config OR1_BI
601	hex
602	default 0x0 if !BR1_MACHINE_UPM
603	default 0x0 if OR1_BI_BURSTSUPPORT
604	default 0x100 if OR1_BI_BURSTINHIBIT
605
606config OR1_COLS
607	hex
608	default 0x0 if !BR1_MACHINE_SDRAM
609	default 0x0 if OR1_COLS_7
610	default 0x400 if OR1_COLS_8
611	default 0x800 if OR1_COLS_9
612	default 0xc00 if OR1_COLS_10
613	default 0x1000 if OR1_COLS_11
614	default 0x1400 if OR1_COLS_12
615	default 0x1800 if OR1_COLS_13
616	default 0x1c00 if OR1_COLS_14
617
618config OR1_ROWS
619	hex
620	default 0x0 if !BR1_MACHINE_SDRAM
621	default 0x0 if OR1_ROWS_9
622	default 0x40 if OR1_ROWS_10
623	default 0x80 if OR1_ROWS_11
624	default 0xc0 if OR1_ROWS_12
625	default 0x100 if OR1_ROWS_13
626	default 0x140 if OR1_ROWS_14
627	default 0x180 if OR1_ROWS_15
628
629config OR1_PMSEL
630	hex
631	default 0x0 if !BR1_MACHINE_SDRAM
632	default 0x0 if OR1_PMSEL_BTB
633	default 0x20 if OR1_PMSEL_KEPT_OPEN
634
635config OR1_SCY
636	hex
637	default 0x0 if !BR1_MACHINE_GPCM && !BR1_MACHINE_FCM
638	default 0x0 if OR1_SCY_0
639	default 0x10 if OR1_SCY_1
640	default 0x20 if OR1_SCY_2
641	default 0x30 if OR1_SCY_3
642	default 0x40 if OR1_SCY_4
643	default 0x50 if OR1_SCY_5
644	default 0x60 if OR1_SCY_6
645	default 0x70 if OR1_SCY_7
646	default 0x80 if OR1_SCY_8
647	default 0x90 if OR1_SCY_9
648	default 0xa0 if OR1_SCY_10
649	default 0xb0 if OR1_SCY_11
650	default 0xc0 if OR1_SCY_12
651	default 0xd0 if OR1_SCY_13
652	default 0xe0 if OR1_SCY_14
653	default 0xf0 if OR1_SCY_15
654
655config OR1_PGS
656	hex
657	default 0x0 if !BR1_MACHINE_FCM
658	default 0x0 if OR1_PGS_SMALL
659	default 0x400 if OR1_PGS_LARGE
660
661config OR1_CSCT
662	hex
663	default 0x0 if !BR1_MACHINE_FCM
664	default 0x0 if OR1_CSCT_1_CYCLE
665	default 0x0 if OR1_CSCT_2_CYCLE
666	default 0x200 if OR1_CSCT_4_CYCLE
667	default 0x200 if OR1_CSCT_8_CYCLE
668
669config OR1_CST
670	hex
671	default 0x0 if !BR1_MACHINE_FCM
672	default 0x0 if OR1_CST_COINCIDENT
673	default 0x100 if OR1_CST_QUARTER_CLOCK
674	default 0x0 if OR1_CST_HALF_CLOCK
675	default 0x100 if OR1_CST_ONE_CLOCK
676
677config OR1_CHT
678	hex
679	default 0x0 if !BR1_MACHINE_FCM
680	default 0x0 if OR1_CHT_HALF_CLOCK
681	default 0x80 if OR1_CHT_ONE_CLOCK
682	default 0x0 if OR1_CHT_ONE_HALF_CLOCK
683	default 0x80 if OR1_CHT_TWO_CLOCK
684
685config OR1_RST
686	hex
687	default 0x0 if !BR1_MACHINE_FCM
688	default 0x0 if OR1_RST_THREE_QUARTER_CLOCK
689	default 0x8 if OR1_RST_ONE_CLOCK
690	default 0x0 if OR1_RST_ONE_HALF_CLOCK
691
692config OR1_CSNT
693	hex
694	default 0x0 if !BR1_MACHINE_GPCM
695	default 0x0 if OR1_CSNT_NORMAL
696	default 0x800 if OR1_CSNT_EARLIER
697
698config OR1_ACS
699	hex
700	default 0x0 if !BR1_MACHINE_GPCM
701	default 0x0 if OR1_ACS_SAME_TIME
702	default 0x400 if OR1_ACS_QUARTER_CYCLE_EARLIER
703	default 0x600 if OR1_ACS_HALF_CYCLE_EARLIER
704
705config OR1_XACS
706	hex
707	default 0x0 if !BR1_MACHINE_GPCM
708	default 0x0 if OR1_XACS_NORMAL
709	default 0x100 if OR1_XACS_EXTENDED
710
711config OR1_SETA
712	hex
713	default 0x0 if !BR1_MACHINE_GPCM
714	default 0x0 if OR1_SETA_INTERNAL
715	default 0x8 if OR1_SETA_EXTERNAL
716
717config OR1_TRLX
718	hex
719	default 0x0 if OR1_TRLX_NORMAL
720	default 0x4 if OR1_TRLX_RELAXED
721
722config OR1_EHTR
723	hex
724	default 0x0 if OR1_EHTR_NORMAL
725	default 0x2 if OR1_EHTR_1_CYCLE
726	default 0x0 if OR1_EHTR_4_CYCLE
727	default 0x2 if OR1_EHTR_8_CYCLE
728
729config OR1_EAD
730	hex
731	default 0x0 if ARCH_MPC8308
732	default 0x0 if OR1_EAD_NONE
733	default 0x1 if OR1_EAD_EXTRA
734