#ifndef __GENERATED_SDRAM_PHY_H #define __GENERATED_SDRAM_PHY_H #include #include #include #define SDRAM_PHY_USDDRPHY #define SDRAM_PHY_PHASES 4 #define SDRAM_PHY_WRITE_LEVELING_CAPABLE #define SDRAM_PHY_WRITE_LEVELING_REINIT #define SDRAM_PHY_READ_LEVELING_CAPABLE #define SDRAM_PHY_MODULES DFII_PIX_DATA_BYTES/2 #define SDRAM_PHY_DELAYS 512 #define SDRAM_PHY_BITSLIPS 8 static void cdelay(int i); __attribute__((unused)) static void command_p0(int cmd) { sdram_dfii_pi0_command_write(cmd); sdram_dfii_pi0_command_issue_write(1); } __attribute__((unused)) static void command_p1(int cmd) { sdram_dfii_pi1_command_write(cmd); sdram_dfii_pi1_command_issue_write(1); } __attribute__((unused)) static void command_p2(int cmd) { sdram_dfii_pi2_command_write(cmd); sdram_dfii_pi2_command_issue_write(1); } __attribute__((unused)) static void command_p3(int cmd) { sdram_dfii_pi3_command_write(cmd); sdram_dfii_pi3_command_issue_write(1); } #define sdram_dfii_pird_address_write(X) sdram_dfii_pi1_address_write(X) #define sdram_dfii_piwr_address_write(X) sdram_dfii_pi2_address_write(X) #define sdram_dfii_pird_baddress_write(X) sdram_dfii_pi1_baddress_write(X) #define sdram_dfii_piwr_baddress_write(X) sdram_dfii_pi2_baddress_write(X) #define command_prd(X) command_p1(X) #define command_pwr(X) command_p2(X) #define DFII_PIX_DATA_SIZE CSR_SDRAM_DFII_PI0_WRDATA_SIZE const unsigned long sdram_dfii_pix_wrdata_addr[SDRAM_PHY_PHASES] = { CSR_SDRAM_DFII_PI0_WRDATA_ADDR, CSR_SDRAM_DFII_PI1_WRDATA_ADDR, CSR_SDRAM_DFII_PI2_WRDATA_ADDR, CSR_SDRAM_DFII_PI3_WRDATA_ADDR }; const unsigned long sdram_dfii_pix_rddata_addr[SDRAM_PHY_PHASES] = { CSR_SDRAM_DFII_PI0_RDDATA_ADDR, CSR_SDRAM_DFII_PI1_RDDATA_ADDR, CSR_SDRAM_DFII_PI2_RDDATA_ADDR, CSR_SDRAM_DFII_PI3_RDDATA_ADDR }; #define DDRX_MR1 769 static void init_sequence(void) { /* Release reset */ sdram_dfii_pi0_address_write(0x0); sdram_dfii_pi0_baddress_write(0); sdram_dfii_control_write(DFII_CONTROL_ODT|DFII_CONTROL_RESET_N); cdelay(50000); /* Bring CKE high */ sdram_dfii_pi0_address_write(0x0); sdram_dfii_pi0_baddress_write(0); sdram_dfii_control_write(DFII_CONTROL_CKE|DFII_CONTROL_ODT|DFII_CONTROL_RESET_N); cdelay(10000); /* Load Mode Register 3 */ sdram_dfii_pi0_address_write(0x0); sdram_dfii_pi0_baddress_write(3); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_CAS|DFII_COMMAND_WE|DFII_COMMAND_CS); /* Load Mode Register 6 */ sdram_dfii_pi0_address_write(0x0); sdram_dfii_pi0_baddress_write(6); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_CAS|DFII_COMMAND_WE|DFII_COMMAND_CS); /* Load Mode Register 5 */ sdram_dfii_pi0_address_write(0x0); sdram_dfii_pi0_baddress_write(5); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_CAS|DFII_COMMAND_WE|DFII_COMMAND_CS); /* Load Mode Register 4 */ sdram_dfii_pi0_address_write(0x0); sdram_dfii_pi0_baddress_write(4); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_CAS|DFII_COMMAND_WE|DFII_COMMAND_CS); /* Load Mode Register 2, CWL=9 */ sdram_dfii_pi0_address_write(0x200); sdram_dfii_pi0_baddress_write(2); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_CAS|DFII_COMMAND_WE|DFII_COMMAND_CS); /* Load Mode Register 1 */ sdram_dfii_pi0_address_write(0x301); sdram_dfii_pi0_baddress_write(1); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_CAS|DFII_COMMAND_WE|DFII_COMMAND_CS); /* Load Mode Register 0, CL=11, BL=8 */ sdram_dfii_pi0_address_write(0x110); sdram_dfii_pi0_baddress_write(0); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_CAS|DFII_COMMAND_WE|DFII_COMMAND_CS); cdelay(200); /* ZQ Calibration */ sdram_dfii_pi0_address_write(0x400); sdram_dfii_pi0_baddress_write(0); command_p0(DFII_COMMAND_WE|DFII_COMMAND_CS); cdelay(200); } #endif