File indexing completed on 2025-05-11 08:23:44
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010 #include <bsp.h>
0011
0012 #define m68k_set_cacr(_cacr) \
0013 __asm__ volatile ("movec %0,%%cacr" : : "d" (_cacr))
0014 #define m68k_set_acr0(_acr0) \
0015 __asm__ volatile ("movec %0,%%acr0" : : "d" (_acr0))
0016 #define m68k_set_acr1(_acr1) \
0017 __asm__ volatile ("movec %0,%%acr1" : : "d" (_acr1))
0018 #define MM_SDRAM_BASE (0x00000000)
0019
0020
0021
0022
0023 extern void CopyDataClearBSSAndStart (void);
0024 extern void INTERRUPT_VECTOR(void);
0025
0026 void Init5282 (void)
0027 {
0028 int x;
0029 int temp = 0;
0030
0031
0032 MCF5282_GPIO_PBCDPAR = 0x80;
0033 MCF5282_GPIO_PEPAR = 0x5100;
0034 MCF5282_GPIO_PJPAR = 0xFF;
0035 MCF5282_GPIO_PASPAR = 0x0000;
0036 MCF5282_GPIO_PEHLPAR = 0xC0;
0037 MCF5282_GPIO_PUAPAR = 0x0F;
0038 MCF5282_QADC_DDRQB = 0x07;
0039 MCF5282_GPTA_GPTDDR = 0x0C;
0040 MCF5282_GPTA_GPTPORT = 0x4;
0041
0042
0043 MCF5282_CS0_CSAR =(0xff800000 & 0xffff0000)>>16;
0044 MCF5282_CS0_CSMR = 0x007f0001;
0045 MCF5282_CS0_CSCR =(((0xf)&0x0F)<<10)|(1<<8)|(0x80);
0046
0047
0048 for(x=0; x<20000; x++) {
0049 temp +=1;
0050 }
0051 MCF5282_SDRAMC_DCR = 0x00000239;
0052 MCF5282_SDRAMC_DACR0 = 0x00001320;
0053 MCF5282_SDRAMC_DMR0 = (0x00FC0000) | (0x00000001);
0054 for(x=0; x<20000; x++) {
0055 temp +=1;
0056 }
0057
0058 MCF5282_SDRAMC_DACR0 |= (0x00000008) ;
0059
0060 *((short *)MM_SDRAM_BASE) = 0;
0061
0062 MCF5282_SDRAMC_DACR0 |= (0x00008000);
0063
0064 for(x=0; x<20000; x++) {
0065 temp +=1;
0066 }
0067
0068 MCF5282_SDRAMC_DACR0 |= (0x00000040);
0069 *((short *)MM_SDRAM_BASE) = 0x0000;
0070 for(x=0; x<60000; x++) {
0071 temp +=1;
0072 }
0073 *((unsigned long*)MM_SDRAM_BASE)=0x12345678;
0074
0075
0076 {
0077 uint32_t *inttab = (uint32_t *)&INTERRUPT_VECTOR;
0078 uint32_t *intvec = (uint32_t *)0x0;
0079 register int i;
0080 for (i = 0; i < 256; i++) {
0081 *(intvec++) = *(inttab++);
0082 }
0083 }
0084
0085
0086
0087 CopyDataClearBSSAndStart ();
0088 }