Initial revision
[platform/kernel/u-boot.git] / doc / README.RPXlite
1 # Porting U-Boot onto RPXlite board
2 # Written by Yoo. Jonghoon
3 # E-Mail : yooth@ipone.co.kr
4 # IP ONE Inc.
5
6 # Since 2001. 1. 29
7
8 # Shell : bash
9 # Cross-compile tools : Montavista Hardhat
10 # Debugging tools : Windriver VisionProbe (PowerPC BDM)
11 # ppcboot ver. : ppcboot-0.8.1
12
13 ###############################################################
14 #       1. Hardware setting
15 ###############################################################
16
17 1.1. Board, BDM settings
18         Install board, BDM, connect each other
19
20 1.2. Save Register value
21         Boot with board-on monitor program and save the
22         register values with BDM.
23
24 1.3. Configure flash programmer
25         Check flash memory area in the memory map.
26         0xFFC00000 - 0xFFFFFFFF
27
28         Boot monitor program is at
29         0xFFF00000
30
31         You can program on-board flash memory with VisionClick
32         flash programmer. Set the target flash device as:
33
34         29DL800B
35
36         (?) The flash memory device in the board *is* 29LV800B,
37                 but I cannot program it with '29LV800B' option.
38                 (in VisionClick flash programming tools)
39                 I don't know why...
40
41 1.4. Save boot monitor program *IMPORTANT*
42         Upload boot monitor program from board to file.
43         boot monitor program starts at 0xFFF00000
44
45 1.5. Test flash memory programming
46         Try to erase boot program in the flash memory,
47         and re-write them.
48         *WARNING* YOU MUST SAVE BOOT PROGRAM TO FILE
49                 BEFORE ERASING FLASH
50
51 ###############################################################
52 #       2. U-Boot setting
53 ###############################################################
54
55 2.1. Download U-Boot tarball at
56         ftp://ftp.denx.de
57         (The latest version is ppcboot-0.8.1.tar.bz2)
58
59         To extract the archive use the following syntax :
60         > bzip2 -cd ppcboot-0.8.1.tar.bz2 | tar xf -
61
62 2.2. Add the following lines in '.profile'
63         export PATH=$PATH:/opt/hardhat/devkit/ppc/8xx/bin
64
65 2.3. Make board specific config, for example:
66         > cd ppcboot-0.8.1
67         > make TQM860L_config
68
69         Now we can build ppcboot bin files.
70         After make all, you must see these files in your
71         ppcboot root directory.
72
73         ppcboot
74         ppcboot.bin
75         ppcboot.srec
76         ppcboot.map
77
78 2.4. Make your own board directory into the
79         ppcboot-0.8.1/board
80         and make your board-specific files here.
81
82         For exmanple, tqm8xx files are composed of
83         .depend : Nothing
84         Makefile : To make config file
85         config.mk : Sets base address
86         flash.c : Flash memory control files
87         ppcboot.lds : linker(ld) script? (I don't know this yet)
88         tqm8xx.c : DRAM control and board check routines
89
90         And, add your board config lines in the
91         ppcboot-0.8.1/Makefile
92
93         Finally, add config_(your board).h file in the
94         ppcboot-0.8.1/include/
95
96         I've made board/rpxlite directory, and just copied
97         tqm8xx settings for now.
98
99         Rebuild ppcboot for rpxlite board:
100         > make rpxlite_config
101         > make
102
103 ###############################################################
104 #       3. U-Boot porting
105 ###############################################################
106
107 3.1. My RPXlite files are based on tqm8xx board files.
108         > cd board
109         > cp -r tqm8xx RPXLITE
110         > cd RPXLITE
111         > mv tqm8xx.c RPXLITE.c
112         > cd ../../include
113         > cp config_tqm8xx.h config_RPXLITE.h
114
115 3.2. Modified files are:
116         board/RPXLITE/RPXLITE.c         /* DRAM-related routines */
117         board/RPXLITE/flash.c           /* flash-related routines */
118         board/RPXLITE/config.mk         /* set text base address */
119         cpu/mpc8xx/serial.c                     /* board specific register setting */
120         include/config_RPXLITE.h        /* board specific registers */
121
122         See 'reg_config.txt' for register values in detail.
123
124 ###############################################################
125 #       4. Running Linux
126 ###############################################################
127
128
129
130
131
132
133
134
135
136 ###############################################################
137 #       Misc Information
138 ###############################################################
139
140 mem_config.txt:
141 ===============
142
143 Flash memory device : AM29LV800BB (1Mx8Bit) x 4 device
144 manufacturer id : 01     (AMD)
145 device id       : 5B     (AM29LV800B)
146 size            : 4Mbyte
147 sector #        : 19
148
149 Sector information :
150
151 number   start addr.     size
152 00       FFC0_0000       64
153 01       FFC1_0000       32
154 02       FFC1_8000       32
155 03       FFC2_0000       128
156 04       FFC4_0000       256
157 05       FFC8_0000       256
158 06       FFCC_0000       256
159 07       FFD0_0000       256
160 08       FFD4_0000       256
161 09       FFD8_0000       256
162 10       FFDC_0000       256
163 11       FFE0_0000       256
164 12       FFE4_0000       256
165 13       FFE8_0000       256
166 14       FFEC_0000       256
167 15       FFF0_0000       256
168 16       FFF4_0000       256
169 17       FFF8_0000       256
170 18       FFFC_0000       256
171
172
173 reg_config.txt:
174 ===============
175
176
177 /*------------------------------------------------------------------- */
178 /*------------------------------------------------------------------- */
179 /*      SIU (System Interface Unit) */
180 /* */
181 /*------------------------------------------------------------------- */
182 /*------------------------------------------------------------------- */
183
184
185 /*### IMMR */
186 /*### Internal Memory Map Register */
187 /*### Chap. 11.4.1 */
188
189         ISB             = 0xFA20                /* Set the Immap base = 0xFA20 0000 */
190         PARTNUM = 0x21
191         MASKNUM = 0x00
192
193         => 0xFA20 2100
194
195 ---------------------------------------------------------------------
196
197 /*### SIUMCR */
198 /*### SIU Module Configuration Register */
199 /*### Chap. 11.4.2 */
200 /*### Offset : 0x0000 0000 */
201
202         EARB    = 0
203         EARP    = 0
204         DSHW    = 0
205         DBGC    = 0
206         DBPC    = 0
207         FRC             = 0
208         DLK             = 0
209         OPAR    = 0
210         PNCS    = 0
211         DPC             = 0
212         MPRE    = 0
213         MLRC    = 10            /* ~KR/~RETRY/~IRQ4/SPKROUT functions as ~KR/~TRTRY */
214         AEME    = 0
215         SEME    = 0
216         BSC             = 0
217         GB5E    = 0
218         B2DD    = 0
219         B3DD    = 0
220
221         => 0x0000 0800
222
223 ---------------------------------------------------------------------
224
225 /*### SYPCR */
226 /*### System Protection Control Register */
227 /*### Chap. 11.4.3 */
228 /*### Offset : 0x0000 0004 */
229
230         SWTC    = 0xFFFF        /* SW watchdog timer count = 0xFFFF */
231         BMT             = 0x06          /* BUS monitoring timing */
232         BME             = 1                     /* BUS monitor enable */
233         SWF             = 1
234         SWE             = 0                     /* SW watchdog disable */
235         SWRI    = 0
236         SWP             = 1
237
238         => 0xFFFF 0689
239
240 ---------------------------------------------------------------------
241
242 /*### TESR */
243 /*### Transfer Error Status Register */
244 /*### Chap. 11.4.4 */
245 /*### Offset : 0x0000 0020 */
246
247         IEXT    = 0
248         ITMT    = 0
249         IPB             = 0000
250         DEXT    = 0
251         DTMT    = 0
252         DPB             = 0000
253
254         => 0x0000 0000
255
256 ---------------------------------------------------------------------
257
258 /*### SIPEND */
259 /*### SIU Interrupt Pending Register */
260 /*### Chap. 11.5.4.1 */
261 /*### Offset : 0x0000 0010 */
262
263         IRQ0~IRQ7 = 0
264         LVL0~LVL7 = 0
265
266         => 0x0000 0000
267
268 ---------------------------------------------------------------------
269
270 /*### SIMASK */
271 /*### SIU Interrupt Mask Register */
272 /*### Chap. 11.5.4.2 */
273 /*### Offset : 0x0000 0014 */
274
275         IRM0~IRM7 = 0           /* Mask all interrupts */
276         LVL0~LVL7 = 0
277
278         => 0x0000 0000
279
280 ---------------------------------------------------------------------
281
282 /*### SIEL */
283 /*### SIU Interrupt Edge/Level Register */
284 /*### Chap. 11.5.4.3 */
285 /*### Offset : 0x0000 0018 */
286
287         ED0~ED7 = 0                     /* Low level triggered */
288         WMn0~WMn7 = 0           /* Not allowed to exit from low-power mode */
289
290         => 0x0000 0000
291
292 ---------------------------------------------------------------------
293
294 /*### SIVEC */
295 /*### SIU Interrupt Vector Register */
296 /*### Chap. 11.5.4.4 */
297 /*### Offset : 0x0000 001C */
298
299         INTC = 3C               /* The lowest interrupt is pending..(?) */
300
301         => 0x3C00 0000
302
303 ---------------------------------------------------------------------
304
305 /*### SWSR */
306 /*### Software Service Register */
307 /*### Chap. 11.7.1 */
308 /*### Offset : 0x0000 001E */
309
310         SEQ = 0
311
312         => 0x0000
313
314 ---------------------------------------------------------------------
315
316 /*### SDCR */
317 /*### SDMA Configuration Register */
318 /*### Chap. 20.2.1 */
319 /*### Offset : 0x0000 0032 */
320
321         FRZ = 0
322         RAID = 01       /* Priority level 5 (BR5) (normal operation) */
323
324         => 0x0000 0001
325
326
327 /*------------------------------------------------------------------- */
328 /*------------------------------------------------------------------- */
329 /*      UPMA (User Programmable Machine A) */
330 /* */
331 /*------------------------------------------------------------------- */
332 /*------------------------------------------------------------------- */
333
334 /*### Chap. 16.6.4.1 */
335 /*### Offset = 0x0000 017c */
336
337         T0  = CFFF CC24         /* Single Read */
338         T1  = 0FFF CC04
339         T2  = 0CAF CC04
340         T3  = 03AF CC08
341         T4  = 3FBF CC27         /* last */
342         T5  = FFFF CC25
343         T6  = FFFF CC25
344         T7  = FFFF CC25
345         T8  = CFFF CC24         /* Burst Read */
346         T9  = 0FFF CC04
347         T10 = 0CAF CC84
348         T11 = 03AF CC88
349         T12 = 3FBF CC27         /* last */
350         T13 = FFFF CC25
351         T14 = FFFF CC25
352         T15 = FFFF CC25
353         T16 = FFFF CC25
354         T17 = FFFF CC25
355         T18 = FFFF CC25
356         T19 = FFFF CC25
357         T20 = FFFF CC25
358         T21 = FFFF CC25
359         T22 = FFFF CC25
360         T23 = FFFF CC25
361         T24 = CFFF CC24         /* Single Write */
362         T25 = 0FFF CC04
363         T26 = 0CFF CC04
364         T27 = 03FF CC00
365         T28 = 3FFF CC27         /* last */
366         T29 = FFFF CC25
367         T30 = FFFF CC25
368         T31 = FFFF CC25
369         T32 = CFFF CC24         /* Burst Write */
370         T33 = 0FFF CC04
371         T34 = 0CFF CC80
372         T35 = 03FF CC8C
373         T36 = 0CFF CC00
374         T37 = 33FF CC27         /* last */
375         T38 = FFFF CC25
376         T39 = FFFF CC25
377         T40 = FFFF CC25
378         T41 = FFFF CC25
379         T42 = FFFF CC25
380         T43 = FFFF CC25
381         T44 = FFFF CC25
382         T45 = FFFF CC25
383         T46 = FFFF CC25
384         T47 = FFFF CC25
385         T48 = C0FF CC24         /* Refresh */
386         T49 = 03FF CC24
387         T50 = 0FFF CC24
388         T51 = 0FFF CC24
389         T52 = 3FFF CC27         /* last */
390         T53 = FFFF CC25
391         T54 = FFFF CC25
392         T55 = FFFF CC25
393         T56 = FFFF CC25
394         T57 = FFFF CC25
395         T58 = FFFF CC25
396         T59 = FFFF CC25
397         T60 = FFFF CC25         /* Exception */
398         T61 = FFFF CC25
399         T62 = FFFF CC25
400         T63 = FFFF CC25
401
402
403 /*------------------------------------------------------------------- */
404 /*------------------------------------------------------------------- */
405 /*      UPMB */
406 /* */
407 /*------------------------------------------------------------------- */
408 /*------------------------------------------------------------------- */
409 ---------------------------------------------------------------------
410
411 /*### Chap. 16.6.4.1 */
412
413
414 /*------------------------------------------------------------------- */
415 /*------------------------------------------------------------------- */
416 /*      MEMC */
417 /* */
418 /*------------------------------------------------------------------- */
419 /*------------------------------------------------------------------- */
420 ---------------------------------------------------------------------
421
422 /*### BR0 & OR0 */
423 /*### Base Registers & Option Registers */
424 /*### Chap. 16.4.1 & 16.4.2 */
425 /*### Offset : BR0(0x0000 0100) & OR0(0x0000 0104) */
426 /*### Flash memory */
427
428         BA   = 1111 1110 0000 0000 0    /* Base addr = 0xFE00 0000 */
429         AT   = 000
430         PS   = 00
431         PARE = 0
432         WP   = 0
433         MS   = 0                                /* GPCM */
434         V    = 1                                /* Valid */
435
436         => 0xFE00 0001
437
438         AM            = 1111 1110 0000 0000 0   /* 32MBytes */
439         ATM           = 000
440         CSNT/SAM      = 0
441         ACS/G5LA,G5LS = 00
442         BIH           = 1                       /* Burst inhibited */
443         SCY           = 0100            /* cycle length = 4 */
444         SETA          = 0
445         TRLX          = 0
446         EHTR          = 0
447
448         => 0xFE00 0140
449
450 /*### BR1 & OR1 */
451 /*### Base Registers & Option Registers */
452 /*### Chap. 16.4.1 & 16.4.2 */
453 /*### Offset : BR1(0x0000 0108) & OR1(0x0000 010C) */
454 /*### SDRAM */
455
456         BA   = 0000 0000 0000 0000 0    /* Base addr = 0x0000 0000 */
457         AT   = 000
458         PS   = 00
459         PARE = 0
460         WP   = 0
461         MS   = 1                                /* UPMA */
462         V    = 1                                /* Valid */
463
464         => 0x0000 0081
465
466         AM            = 1111 1110 0000 0000     /* 32MBytes */
467         ATM           = 000
468         CSNT/SAM      = 1
469         ACS/G5LA,G5LS = 11
470         BIH           = 0
471         SCY           = 0000            /* cycle length = 0 */
472         SETA          = 0
473         TRLX          = 0
474         EHTR          = 0
475
476         => 0xFE00 0E00
477
478 /*### BR2 & OR2 */
479 /*### Base Registers & Option Registers */
480 /*### Chap. 16.4.1 & 16.4.2 */
481 /*### Offset : BR2(0x0000 0110) & OR2(0x0000 0114) */
482
483         BR2 & OR2 = 0x0000 0000         /* Not used */
484
485 /*### BR3 & OR3 */
486 /*### Base Registers & Option Registers */
487 /*### Chap. 16.4.1 & 16.4.2 */
488 /*### Offset : BR3(0x0000 0118) & OR3(0x0000 011C) */
489 /*### BCSR */
490
491         BA   = 1111 1010 0100 0000 0    /* Base addr = 0xFA40 0000 */
492         AT   = 000
493         PS   = 00
494         PARE = 0
495         WP   = 0
496         MS   = 0                                /* GPCM */
497         V    = 1                                /* Valid */
498
499         => 0xFA40 0001
500
501         AM            = 1111 1111 0111 1111 1   /* (?) */
502         ATM           = 000
503         CSNT/SAM      = 1
504         ACS/G5LA,G5LS = 00
505         BIH           = 1                       /* Burst inhibited */
506         SCY           = 0001            /* cycle length = 1 */
507         SETA          = 0
508         TRLX          = 0
509
510         => 0xFF7F 8910
511
512 /*### BR4 & OR4 */
513 /*### Base Registers & Option Registers */
514 /*### Chap. 16.4.1 & 16.4.2 */
515 /*### Offset : BR4(0x0000 0120) & OR4(0x0000 0124) */
516 /*### NVRAM & SRAM */
517
518         BA   = 1111 1010 0000 0000 0    /* Base addr = 0xFA00 0000 */
519         AT   = 000
520         PS   = 01
521         PARE = 0
522         WP   = 0
523         MS   = 0                                /* GPCM */
524         V    = 1                                /* Valid */
525
526         => 0xFA00 0401
527
528         AM            = 1111 1111 1111 1000 0   /* 8MByte */
529         ATM           = 000
530         CSNT/SAM      = 1
531         ACS/G5LA,G5LS = 00
532         BIH           = 1                       /* Burst inhibited */
533         SCY           = 0111            /* cycle length = 7 */
534         SETA          = 0
535         TRLX          = 0
536
537         => 0xFFF8 0970
538
539 /*### BR5 & OR5 */
540 /*### Base Registers & Option Registers */
541 /*### Chap. 16.4.1 & 16.4.2 */
542 /*### Offset : BR2(0x0000 0128) & OR2(0x0000 012C) */
543
544         BR5 & OR5 = 0x0000 0000         /* Not used */
545
546 /*### BR6 & OR6 */
547 /*### Base Registers & Option Registers */
548 /*### Chap. 16.4.1 & 16.4.2 */
549 /*### Offset : BR2(0x0000 0130) & OR2(0x0000 0134) */
550
551         BR6 & OR6 = 0x0000 0000         /* Not used */
552
553 /*### BR7 & OR7 */
554 /*### Base Registers & Option Registers */
555 /*### Chap. 16.4.1 & 16.4.2 */
556 /*### Offset : BR7(0x0000 0138) & OR7(0x0000 013C) */
557
558         BR7 & OR7 = 0x0000 0000         /* Not used */
559
560 /*### MAR */
561 /*### Memory Address Register */
562 /*### Chap. 16.4.7 */
563 /*### Offset : 0x0000 0164 */
564
565         MA = External memory address
566
567 /*### MCR */
568 /*### Memory Command Register */
569 /*### Chap. 16.4.5 */
570 /*### Offset : 0x0000 0168 */
571
572         OP   = xx                       /* Command op code */
573         UM   = 1                        /* Select UPMA */
574         MB   = 001                      /* Select CS1 */
575         MCLF = xxxx                     /* Loop times */
576         MAD  = xx xxxx          /* Memory array index */
577
578 /*### MAMR */
579 /*### Machine A Mode Register */
580 /*### Chap. 16.4.4 */
581 /*### Offset : 0x0000 0170 */
582
583         PTA = 0101 1000
584         PTAE = 1                        /* Periodic timer A enabled */
585         AMA = 010
586         DSA = 00
587         G0CLA = 000
588         GPLA4DIS = 1
589         RLFA = 0100
590         WLFA = 0011
591         TLFA = 0000
592
593         => 0x58A0 1430
594
595 /*### MBMR */
596 /*### Machine B Mode Register */
597 /*### Chap. 16.4.4 */
598 /*### Offset : 0x0000 0174 */
599
600         PTA = 0100 1110
601         PTAE = 0                        /* Periodic timer B disabled */
602         AMA = 000
603         DSA = 00
604         G0CLA = 000
605         GPLA4DIS = 1
606         RLFA = 0000
607         WLFA = 0000
608         TLFA = 0000
609
610         => 0x4E00 1000
611
612 /*### MSTAT */
613 /*### Memory Status Register */
614 /*### Chap. 16.4.3 */
615 /*### Offset : 0x0000 0178 */
616
617         PER0~PER7 = Parity error
618         WPER      = Write protection error
619
620         => 0x0000
621
622 /*### MPTPR */
623 /*### Memory Periodic Timer Prescaler Register */
624 /*### Chap. 16.4.8 */
625 /*### Offset : 0x0000 017A */
626
627         PTP = 0000 1000         /* Divide by 8 */
628
629         => 0x0800
630
631 /*### MDR */
632 /*### Memory Data Register */
633 /*### Chap. 16.4.6 */
634 /*### Offset : 0x0000 017C */
635
636         MD = Memory data contains the RAM array word
637
638
639 /*------------------------------------------------------------------- */
640 /*------------------------------------------------------------------- */
641 /*      TIMERS */
642 /* */
643 /*------------------------------------------------------------------- */
644 /*------------------------------------------------------------------- */
645 ---------------------------------------------------------------------
646
647 /*### TBREFx */
648 /*### Timebase Reference Registers */
649 /*### Chap. 11.9.2 */
650 /*### Offset : TBREFF0(0x0000 0204)/TBREFF1(0x0000 0208) */
651 /*### (Locked) */
652
653         TBREFF0 = 0xFFFF FFFF
654         TBREFF1 = 0xFFFF FFFF
655
656 ---------------------------------------------------------------------
657
658 /*### TBSCR */
659 /*### Timebase Status and Control Registers */
660 /*### Chap. 11.9.3 */
661 /*### Offset : 0x0000 0200 */
662 /*### (Locked) */
663
664         TBIRQ = 00000000
665         REF0  = 0
666         REF1  = 0
667         REFE0 = 0                       /* Reference interrupt disable */
668         REFE1 = 0
669         TBF   = 1
670         TBE   = 1                       /* Timebase enable */
671
672         => 0x0003
673
674 ---------------------------------------------------------------------
675
676 /*### RTCSC */
677 /*### Real-Time Clock Status and Control Registers */
678 /*### Chap. 11.10.1 */
679 /*### Offset : 0x0000 0220 */
680 /*### (Locked) */
681
682         RTCIRQ = 00000000
683         SEC = 1
684         ALR = 0
685         38K = 0                         /* PITRTCLK is driven by 32.768KHz */
686         SIE = 0
687         ALE = 0
688         RTF = 0
689         RTE = 1                         /* Real-Time clock enabled */
690
691         => 0x0081
692
693 ---------------------------------------------------------------------
694
695 /*### RTC */
696 /*### Real-Time Clock Registers */
697 /*### Chap. 11.10.2 */
698 /*### Offset : 0x0000 0224 */
699 /*### (Locked) */
700
701         RTC = Real time clock measured in second
702
703 ---------------------------------------------------------------------
704
705 /*### RTCAL */
706 /*### Real-Time Clock Alarm Registers */
707 /*### Chap. 11.10.3 */
708 /*### Offset : 0x0000 022C */
709 /*### (Locked) */
710
711         ALARM = 0xFFFF FFFF
712
713 ---------------------------------------------------------------------
714
715 /*### RTSEC */
716 /*### Real-Time Clock Alarm Second Registers */
717 /*### Chap. 11.10.4 */
718 /*### Offset : 0x0000 0228 */
719 /*### (Locked) */
720
721         COUNTER = Counter bits(fraction of a second)
722
723 ---------------------------------------------------------------------
724
725 /*### PISCR */
726 /*### Periodic Interrupt Status and Control Register */
727 /*### Chap. 11.11.1 */
728 /*### Offset : 0x0000 0240 */
729 /*### (Locked) */
730
731         PIRQ = 0
732         PS   = 0                /* Write 1 to clear */
733         PIE  = 0
734         PITF = 1
735         PTE  = 0                /* PIT disabled */
736
737 ---------------------------------------------------------------------
738
739 /*### PITC */
740 /*### PIT Count Register */
741 /*### Chap. 11.11.2 */
742 /*### Offset : 0x0000 0244 */
743 /*### (Locked) */
744
745         PITC = PIT count
746
747 ---------------------------------------------------------------------
748
749 /*### PITR */
750 /*### PIT Register */
751 /*### Chap. 11.11.3 */
752 /*### Offset : 0x0000 0248 */
753 /*### (Locked) */
754
755         PIT = PIT count         /* Read only */
756
757
758
759 /*------------------------------------------------------------------- */
760 /*------------------------------------------------------------------- */
761 /*      CLOCKS */
762 /* */
763 /*------------------------------------------------------------------- */
764 /*------------------------------------------------------------------- */
765 ---------------------------------------------------------------------
766
767
768 ---------------------------------------------------------------------
769
770 /*### SCCR */
771 /*### System Clock and Reset Control Register */
772 /*### Chap. 15.6.1 */
773 /*### Offset : 0x0000 0280 */
774 /*### (Locked) */
775
776         COM    = 11             /* Clock output disabled */
777         TBS    = 1              /* Timebase frequency source is GCLK2 divided by 16 */
778         RTDIV  = 0              /* The clock is divided by 4 */
779         RTSEL  = 0              /* OSCM(Crystal oscillator) is selected */
780         CRQEN  = 0
781         PRQEN  = 0
782         EBDF   = 00             /* CLKOUT is GCLK2 divided by 1 */
783         DFSYNC = 00             /* Divided by 1 (normal operation) */
784         DFBRG  = 00             /* Divided by 1 (normal operation) */
785         DFNL   = 000
786         DFNH   = 000
787
788         => 0x6200 0000
789
790 ---------------------------------------------------------------------
791
792 /*### PLPRCR */
793 /*### PLL, Low-Power, and Reset Control Register */
794 /*### Chap. 15.6.2 */
795 /*### Offset : 0x0000 0284 */
796 /*### (Locked) */
797
798         MF    = 0x005   /* 48MHz (?) (  = 8MHz * (MF+1) ) */
799         SPLSS = 0
800         TEXPS = 0
801         TMIST = 0
802         CSRC  = 0               /* The general system clock is generated by the DFNH field */
803         LPM   = 00              /* Normal high/normal low mode */
804         CSR   = 0
805         LOLRE = 0
806         FIOPD = 0
807
808         => 0x0050 0000
809
810 ---------------------------------------------------------------------
811
812 /*### RSR */
813 /*### Reset Status Register */
814 /*### Chap. 12.2 */
815 /*### Offset : 0x0000 0288 */
816 /*### (Locked) */
817
818         EHRS  = External hard reset
819         ESRS  = External soft reset
820         LLRS  = Loss-of-lock reset
821         SWRS  = Software watchdog reset
822         CSRS  = Check stop reset
823         DBHRS = Debug port hard reset
824         DBSRS = Debug port soft reset
825         JTRS  = JTAG reset
826
827
828
829 /*------------------------------------------------------------------- */
830 /*------------------------------------------------------------------- */
831 /*      DMA */
832 /* */
833 /*------------------------------------------------------------------- */
834 /*------------------------------------------------------------------- */
835 ---------------------------------------------------------------------
836
837 /*### SDSR */
838 /*### SDMA Status Register */
839 /*### Chap. 20.2.2 */
840 /*### Offset : 0x0000 0908 */
841
842         SBER = 0        /* SDMA channel bus error */
843         DSP2 = 0        /* DSP chain2 (Tx) interrupt */
844         DSP1 = 0        /* DSP chain1 (Rx) interrupt */
845
846         => 0x00
847
848 /*### SDMR */
849 /*### SDMA Mask Register */
850 /*### Chap. 20.2.3 */
851 /*### Offset : 0x0000 090C */
852
853         SBER = 0
854         DSP2 = 0
855         DSP1 = 0        /* All interrupts are masked */
856
857         => 0x00
858
859 /*### SDAR */
860 /*### SDMA Address Register */
861 /*### Chap. 20.2.4 */
862 /*### Offset : 0x0000 0904 */
863
864         AR = 0xxxxx xxxx        /* current system address */
865
866         => 0xFA20 23AC
867
868 /*### IDSRx */
869 /*### IDMA Status Register */
870 /*### Chap. 20.3.3.2 */
871 /*### Offset : IDSR1(0x0000 0910) & IDSR2(0x0000 0918) */
872
873         AD   = 0
874         DONE = 0
875         OB   = 0
876
877         => 0x00
878
879 /*### IDMRx */
880 /*### IDMA Mask Register */
881 /*### Chap. 20.3.3.3 */
882 /*### Offset : IDMR1(0x0000 0914) & IDMR2(0x0000 091C) */
883
884         AD   = 0
885         DONE = 0
886         OB   = 0
887