📄 uboot-20061030-qt2410.patch
字号:
+ int cflag, iflag;+ int chip;++ /*+ * Check if Flash is (sufficiently) erased+ */+ result = *addr;+ if ((result & data) != data)+ return ERR_NOT_ERASED;+++ /*+ * Disable interrupts which might cause a timeout+ * here. Remember that our exception vectors are+ * at address 0 in the flash, and we don't want a+ * (ticker) exception to happen while the flash+ * chip is in programming mode.+ */+ cflag = icache_status ();+ icache_disable ();+ iflag = disable_interrupts ();++ MEM_FLASH_ADDR1 = CMD_UNLOCK1;+ MEM_FLASH_ADDR2 = CMD_UNLOCK2;+ MEM_FLASH_ADDR1 = CMD_UNLOCK_BYPASS;+ *addr = CMD_PROGRAM;+ *addr = data;++ /* arm simple, non interrupt dependent timer */+ reset_timer_masked ();++ /* wait until flash is ready */+ chip = 0;+ do {+ result = *addr;++ /* check timeout */+ if (get_timer_masked () > CFG_FLASH_ERASE_TOUT) {+ chip = ERR | TMO;+ break;+ }+ if (!chip && ((result & 0x80) == (data & 0x80)))+ chip = READY;++ if (!chip && ((result & 0xFFFF) & BIT_PROGRAM_ERROR)) {+ result = *addr;++ if ((result & 0x80) == (data & 0x80))+ chip = READY;+ else+ chip = ERR;+ }++ } while (!chip);++ *addr = CMD_READ_ARRAY;++ if (chip == ERR || *addr != data)+ rc = ERR_PROG_ERROR;++ if (iflag)+ enable_interrupts ();++ if (cflag)+ icache_enable ();++ return rc;+}++/*-----------------------------------------------------------------------+ * Copy memory to flash.+ */++int write_buff (flash_info_t * info, uchar * src, ulong addr, ulong cnt)+{+ ulong cp, wp;+ int l;+ int i, rc;+ ushort data;++ wp = (addr & ~1); /* get lower word aligned address */++ /*+ * handle unaligned start bytes+ */+ if ((l = addr - wp) != 0) {+ data = 0;+ for (i = 0, cp = wp; i < l; ++i, ++cp) {+ data = (data >> 8) | (*(uchar *) cp << 8);+ }+ for (; i < 2 && cnt > 0; ++i) {+ data = (data >> 8) | (*src++ << 8);+ --cnt;+ ++cp;+ }+ for (; cnt == 0 && i < 2; ++i, ++cp) {+ data = (data >> 8) | (*(uchar *) cp << 8);+ }++ if ((rc = write_hword (info, wp, data)) != 0) {+ return (rc);+ }+ wp += 2;+ }++ /*+ * handle word aligned part+ */+ while (cnt >= 2) {+ data = *((vu_short *) src);+ if ((rc = write_hword (info, wp, data)) != 0) {+ return (rc);+ }+ src += 2;+ wp += 2;+ cnt -= 2;+ }++ if (cnt == 0) {+ return ERR_OK;+ }++ /*+ * handle unaligned tail bytes+ */+ data = 0;+ for (i = 0, cp = wp; i < 2 && cnt > 0; ++i, ++cp) {+ data = (data >> 8) | (*src++ << 8);+ --cnt;+ }+ for (; i < 2; ++i, ++cp) {+ data = (data >> 8) | (*(uchar *) cp << 8);+ }++ return write_hword (info, wp, data);+}Index: u-boot/board/qt2410/lowlevel_init.S===================================================================--- /dev/null+++ u-boot/board/qt2410/lowlevel_init.S@@ -0,0 +1,171 @@+/*+ * Memory Setup stuff - taken from blob memsetup.S+ *+ * Copyright (C) 1999 2000 2001 Erik Mouw (J.A.K.Mouw@its.tudelft.nl) and+ * Jan-Derk Bakker (J.D.Bakker@its.tudelft.nl)+ *+ * Modified for the Samsung SMDK2410 by+ * (C) Copyright 2002+ * David Mueller, ELSOFT AG, <d.mueller@elsoft.ch>+ *+ * See file CREDITS for list of people who contributed to this+ * project.+ *+ * This program is free software; you can redistribute it and/or+ * modify it under the terms of the GNU General Public License as+ * published by the Free Software Foundation; either version 2 of+ * the License, or (at your option) any later version.+ *+ * This program is distributed in the hope that it will be useful,+ * but WITHOUT ANY WARRANTY; without even the implied warranty of+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the+ * GNU General Public License for more details.+ *+ * You should have received a copy of the GNU General Public License+ * along with this program; if not, write to the Free Software+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,+ * MA 02111-1307 USA+ */+++#include <config.h>+#include <version.h>+++/* some parameters for the board */++/*+ *+ * Taken from linux/arch/arm/boot/compressed/head-s3c2410.S+ *+ * Copyright (C) 2002 Samsung Electronics SW.LEE <hitchcar@sec.samsung.com>+ *+ */++#define BWSCON 0x48000000++/* BWSCON */+#define DW8 (0x0)+#define DW16 (0x1)+#define DW32 (0x2)+#define WAIT (0x1<<2)+#define UBLB (0x1<<3)++#define B1_BWSCON (DW32)+#define B2_BWSCON (DW16)+#define B3_BWSCON (DW16 + WAIT + UBLB)+#define B4_BWSCON (DW16)+#define B5_BWSCON (DW16)+#define B6_BWSCON (DW32)+#define B7_BWSCON (DW32)++/* BANK0CON */+#define B0_Tacs 0x0 /* 0clk */+#define B0_Tcos 0x0 /* 0clk */+#define B0_Tacc 0x7 /* 14clk */+#define B0_Tcoh 0x0 /* 0clk */+#define B0_Tah 0x0 /* 0clk */+#define B0_Tacp 0x0+#define B0_PMC 0x0 /* normal */++/* BANK1CON */+#define B1_Tacs 0x0 /* 0clk */+#define B1_Tcos 0x0 /* 0clk */+#define B1_Tacc 0x7 /* 14clk */+#define B1_Tcoh 0x0 /* 0clk */+#define B1_Tah 0x0 /* 0clk */+#define B1_Tacp 0x0+#define B1_PMC 0x0++#define B2_Tacs 0x0+#define B2_Tcos 0x0+#define B2_Tacc 0x7+#define B2_Tcoh 0x0+#define B2_Tah 0x0+#define B2_Tacp 0x0+#define B2_PMC 0x0++#define B3_Tacs 0x0 /* 0clk */+#define B3_Tcos 0x3 /* 4clk */+#define B3_Tacc 0x7 /* 14clk */+#define B3_Tcoh 0x1 /* 1clk */+#define B3_Tah 0x0 /* 0clk */+#define B3_Tacp 0x3 /* 6clk */+#define B3_PMC 0x0 /* normal */++#define B4_Tacs 0x0 /* 0clk */+#define B4_Tcos 0x0 /* 0clk */+#define B4_Tacc 0x7 /* 14clk */+#define B4_Tcoh 0x0 /* 0clk */+#define B4_Tah 0x0 /* 0clk */+#define B4_Tacp 0x0+#define B4_PMC 0x0 /* normal */++#define B5_Tacs 0x0 /* 0clk */+#define B5_Tcos 0x0 /* 0clk */+#define B5_Tacc 0x7 /* 14clk */+#define B5_Tcoh 0x0 /* 0clk */+#define B5_Tah 0x0 /* 0clk */+#define B5_Tacp 0x0+#define B5_PMC 0x0 /* normal */++#define B6_MT 0x3 /* SDRAM */+#define B6_Trcd 0x1+#define B6_SCAN 0x1 /* 9bit */++#define B7_MT 0x3 /* SDRAM */+#define B7_Trcd 0x1 /* 3clk */+#define B7_SCAN 0x1 /* 9bit */++/* REFRESH parameter */+#define REFEN 0x1 /* Refresh enable */+#define TREFMD 0x0 /* CBR(CAS before RAS)/Auto refresh */+#define Trp 0x1 /* 3clk */+#define Trc 0x3 /* 7clk */+#define Tchr 0x2 /* 3clk */+//#define REFCNT 1113 /* period=15.6us, HCLK=60Mhz, (2048+1-15.6*60) */+#define REFCNT 997 /* period=17.5us, HCLK=60Mhz, (2048+1-15.6*60) */+/**************************************/++_TEXT_BASE:+ .word TEXT_BASE++.globl lowlevel_init+lowlevel_init:+ /* memory control configuration */+ /* make r0 relative the current location so that it */+ /* reads SMRDATA out of FLASH rather than memory ! */+ adr r0, SMRDATA+ ldr r1, =BWSCON /* Bus Width Status Controller */+ add r2, r0, #13*4+0:+ ldr r3, [r0], #4+ str r3, [r1], #4+ cmp r2, r0+ bne 0b++ /* setup asynchronous bus mode */+ mrc p15, 0, r1 ,c1 ,c0, 0+ orr r1, r1, #0xc0000000+ mcr p15, 0, r1, c1, c0, 0++ /* everything is fine now */+ mov pc, lr++ .ltorg+/* the literal pools origin */++SMRDATA:+ .word (0+(B1_BWSCON<<4)+(B2_BWSCON<<8)+(B3_BWSCON<<12)+(B4_BWSCON<<16)+(B5_BWSCON<<20)+(B6_BWSCON<<24)+(B7_BWSCON<<28))+ .word ((B0_Tacs<<13)+(B0_Tcos<<11)+(B0_Tacc<<8)+(B0_Tcoh<<6)+(B0_Tah<<4)+(B0_Tacp<<2)+(B0_PMC))+ .word ((B1_Tacs<<13)+(B1_Tcos<<11)+(B1_Tacc<<8)+(B1_Tcoh<<6)+(B1_Tah<<4)+(B1_Tacp<<2)+(B1_PMC))+ .word ((B2_Tacs<<13)+(B2_Tcos<<11)+(B2_Tacc<<8)+(B2_Tcoh<<6)+(B2_Tah<<4)+(B2_Tacp<<2)+(B2_PMC))+ .word ((B3_Tacs<<13)+(B3_Tcos<<11)+(B3_Tacc<<8)+(B3_Tcoh<<6)+(B3_Tah<<4)+(B3_Tacp<<2)+(B3_PMC))+ .word ((B4_Tacs<<13)+(B4_Tcos<<11)+(B4_Tacc<<8)+(B4_Tcoh<<6)+(B4_Tah<<4)+(B4_Tacp<<2)+(B4_PMC))+ .word ((B5_Tacs<<13)+(B5_Tcos<<11)+(B5_Tacc<<8)+(B5_Tcoh<<6)+(B5_Tah<<4)+(B5_Tacp<<2)+(B5_PMC))+ .word ((B6_MT<<15)+(B6_Trcd<<2)+(B6_SCAN))+ .word ((B7_MT<<15)+(B7_Trcd<<2)+(B7_SCAN))+ .word ((REFEN<<23)+(TREFMD<<22)+(Trp<<20)+(Trc<<18)+(Tchr<<16)+REFCNT)+ .word 0xb2+ .word 0x30+ .word 0x30Index: u-boot/board/qt2410/qt2410.c===================================================================--- /dev/null+++ u-boot/board/qt2410/qt2410.c@@ -0,0 +1,152 @@+/*+ * (C) 2006 by OpenMoko, Inc.+ * Author: Harald Welte <laforge@openmoko.org>+ *+ * based on existing S3C2410 startup code in u-boot:+ *+ * (C) Copyright 2002+ * Sysgo Real-Time Solutions, GmbH <www.elinos.com>+ * Marius Groeger <mgroeger@sysgo.de>+ *+ * (C) Copyright 2002+ * David Mueller, ELSOFT AG, <d.mueller@elsoft.ch>+ *+ * See file CREDITS for list of people who contributed to this+ * project.+ *+ * This program is free software; you can redistribute it and/or+ * modify it under the terms of the GNU General Public License as+ * published by the Free Software Foundation; either version 2 of+ * the License, or (at your option) any later version.+ *+ * This program is distributed in the hope that it will be useful,+ * but WITHOUT ANY WARRANTY; without even the implied warranty of+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the+ * GNU General Public License for more details.+ *+ * You should have received a copy of the GNU General Public License+ * along with this program; if not, write to the Free Software+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,+ * MA 02111-1307 USA+ */++#include <common.h>+#include <video_fb.h>+#include <usbdcore.h>+#include <s3c2410.h>++DECLARE_GLOBAL_DATA_PTR;++#if 1+//#define M_MDIV 0xA1 /* Fout = 202.8MHz */+//#define M_PDIV 0x3+//#define M_SDIV 0x1+#define M_MDIV 0x90 /* Fout = 202.8MHz */+#define M_PDIV 0x7+#define M_SDIV 0x0+#else+#define M_MDIV 0x5c /* Fout = 150.0MHz */+#define M_PDIV 0x4+#define M_SDIV 0x0+#endif++#if 1+#define U_M_MDIV 0x78+#define U_M_PDIV 0x2+#define U_M_SDIV 0x3+#else+#define U_M_MDIV 0x48+#define U_M_PDIV 0x3+#define U_M_SDIV 0x2+#endif++static inline void delay (unsigned long loops)+{+ __asm__ volatile ("1:\n"+ "subs %0, %1, #1\n"+ "bne 1b":"=r" (loops):"0" (loops));+}++/*+ * Miscellaneous platform dependent initialisations+ */++int board_init (void)+{+ S3C24X0_CLOCK_POWER * const clk_power = S3C24X0_GetBase_CLOCK_POWER();+ S3C24X0_GPIO * const gpio = S3C24X0_GetBase_GPIO();++ /* to reduce PLL lock time, adjust the LOCKTIME register */+ clk_power->LOCKTIME = 0xFFFFFF;++ /* configure MPLL */+ clk_power->MPLLCON = ((M_MDIV << 12) + (M_PDIV << 4) + M_SDIV);++ /* some delay between MPLL and UPLL */+ delay (4000);++ /* configure UPLL */+ clk_power->UPLLCON = ((U_M_MDIV << 12) + (U_M_PDIV << 4) + U_M_SDIV);++ /* some delay between MPLL and UPLL */+ delay (8000);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -