⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 uboot-20061030-neo1973.patch

📁 Uboot常用的移植patches, 方便定制移植到s3c2440
💻 PATCH
📖 第 1 页 / 共 5 页
字号:
+int jbt6k74_enter_state(enum jbt_state new_state);++#endifIndex: u-boot/board/neo1973/common/lowlevel_init.S===================================================================--- /dev/null+++ u-boot/board/neo1973/common/lowlevel_init.S@@ -0,0 +1,187 @@+/*+ * 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 FIC Neo1973 GTA01 by Harald Welte <laforge@openmoko.org>+ *+ * 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	/* 3clk */+#if defined (CONFIG_ARCH_GTA01_v3) || defined(CONFIG_ARCH_GTA01_v4)+#define B6_SCAN		 	0x1	/* 9bit */+#elif defined(CONFIG_ARCH_GTA01B_v2) || defined(CONFIG_ARCH_GTA01B_v3) || \+      defined(CONFIG_ARCH_GTA01B_v4)+#define B6_SCAN		 	0x2	/* 10bit */+#endif++#define B7_MT		 	0x3	/* SDRAM */+#define B7_Trcd		 	0x1	/* 3clk */+#define B7_SCAN		 	0x2	/* 10bit */++/* 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++#if defined(CONFIG_ARCH_GTA01_v4) || defined(CONFIG_ARCH_GTA01B_v2) || defined(CONFIG_ARCH_GTA01B_v3)+	/* switch on power for NAND */+	ldr	r0, =0x56000010	/* GPBCON */+	ldr	r1, [r0]+	orr	r1, r1, #0x10+	str	r1, [r0]++	ldr	r0, =0x56000014	/* GPBDAT */+	ldr	r1, [r0]+	orr	r1, r1, #(1 <<2)+	str	r1, [r0]+#endif++	/* 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/neo1973/gta01/Makefile===================================================================--- /dev/null+++ u-boot/board/neo1973/gta01/Makefile@@ -0,0 +1,48 @@+#+# (C) Copyright 2000, 2001, 2002+# Wolfgang Denk, DENX Software Engineering, wd@denx.de.+#+# 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 $(TOPDIR)/config.mk++LIB	= lib$(BOARD).a++OBJS	:= gta01.o pcf50606.o ../common/cmd_neo1973.o ../common/jbt6k74.o \+	   ../common/gsmver.o+SOBJS	:= ../common/lowlevel_init.o++$(LIB):	$(OBJS) $(SOBJS)+	$(AR) crv $@ $(OBJS) $(SOBJS)++clean:+	rm -f $(SOBJS) $(OBJS)++distclean:	clean+	rm -f $(LIB) core *.bak .depend++#########################################################################++.depend:	Makefile $(SOBJS:.o=.S) $(OBJS:.o=.c)+		$(CC) -M $(CPPFLAGS) $(SOBJS:.o=.S) $(OBJS:.o=.c) > $@++-include .depend++#########################################################################Index: u-boot/board/neo1973/gta01/config.mk===================================================================--- /dev/null+++ u-boot/board/neo1973/gta01/config.mk@@ -0,0 +1,34 @@+#+# (C) Copyright 2002+# Gary Jennejohn, DENX Software Engineering, <gj@denx.de>+# David Mueller, ELSOFT AG, <d.mueller@elsoft.ch>+#+# FIC Neo1973 GTA01 board with S3C2410X (ARM920T) cpu+#+# see http://www.samsung.com/ for more information on SAMSUNG+#++# GTA01v3 has 1 bank of 64 MB SDRAM+# GTA01v4 has 1 bank of 64 MB SDRAM+#+# 	3000'0000 to 3400'0000+# we load ourself to 33F8'0000+#+# GTA01Bv2 or later has 1 bank of 128 MB SDRAM+#+# 	3000'0000 to 3800'0000+# we load ourself to 37F8'0000+#+# Linux-Kernel is expected to be at 3000'8000, entry 3000'8000+# optionally with a ramdisk at 3080'0000+#+# download area is 3200'0000 or 3300'0000++sinclude $(OBJTREE)/board/$(BOARDDIR)/config.tmp++ifeq ($(GTA01_BIG_RAM),y)+# FIXME: TEXT_BASE = 0x37F80000+TEXT_BASE = 0x33F80000+else+TEXT_BASE = 0x33F80000+endifIndex: u-boot/board/neo1973/gta01/gta01.c===================================================================--- /dev/null+++ u-boot/board/neo1973/gta01/gta01.c@@ -0,0 +1,491 @@+/*+ * (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 <devices.h>+#include <s3c2410.h>+#include <i2c.h>++#include "pcf50606.h"++#include "../common/neo1973.h"+#include "../common/jbt6k74.h"++DECLARE_GLOBAL_DATA_PTR;++/* That many seconds the power key needs to be pressed to power up */+#define POWER_KEY_SECONDS	2++#if defined(CONFIG_ARCH_GTA01_v3) || defined(CONFIG_ARCH_GTA01_v4)+//#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+#elif defined(CONFIG_ARCH_GTA01B_v2) || defined(CONFIG_ARCH_GTA01B_v3)+/* In case the debug board is attached, we cannot go beyond 200 MHz */+#if 0+#define M_MDIV	0x7d		/* Fout = 266MHz */+#define M_PDIV	0x1+#define M_SDIV	0x1+#else+#define M_MDIV	0x90		/* Fout = 202.8MHz */+#define M_PDIV	0x7+#define M_SDIV	0x0+#endif+#elif defined(CONFIG_ARCH_GTA01B_v4)+/* This board doesn't have bus lines at teh debug port, and we can go to 266 */+#define M_MDIV	0x7d		/* Fout = 266MHz */+#define M_PDIV	0x1+#define M_SDIV	0x1+#else+#error Please define GTA01 revision+#endif++#define U_M_MDIV	0x78+#define U_M_PDIV	0x2+#define U_M_SDIV	0x3++unsigned int neo1973_wakeup_cause;+extern int nobootdelay;++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);++	/* set up the I/O ports */+#if defined(CONFIG_ARCH_GTA01_v3)+	gpio->GPACON = 0x007FFFFF;++	gpio->GPBCON = 0x00005055;+	gpio->GPBUP = 0x000007FF;++	gpio->GPCCON = 0xAAAA12A8;+	gpio->GPCUP = 0x0000FFFF;++	gpio->GPDCON = 0xAAAAAAAA;+	gpio->GPDUP = 0x0000FFFF;++	gpio->GPECON = 0xAAAAAAAA;+	gpio->GPEUP = 0x0000FFFF;++	gpio->GPFCON = 0x00002AA9;+	gpio->GPFUP = 0x000000FF;++	gpio->GPGCON = 0xA846F0C0;+	gpio->GPGUP = 0x0000AFEF;++	gpio->GPHCON = 0x0008FAAA;+	gpio->GPHUP = 0x000007FF;+#elif defined(CONFIG_ARCH_GTA01_v4)+	gpio->GPACON = 0x005E47FF;++	gpio->GPBCON = 0x00045015;+	gpio->GPBUP = 0x000007FF;+	gpio->GPBDAT |= 0x4;		/* Set GPB2 to high (Flash power-up) */++	gpio->GPCCON = 0xAAAA12A9;+	gpio->GPCUP = 0x0000FFFF;++	gpio->GPDCON = 0xAAAAAAAA;+	gpio->GPDUP = 0x0000FFFF;++	gpio->GPECON = 0xA02AAAAA;+	gpio->GPEUP = 0x0000FFFF;++	gpio->GPFCON = 0x0000aa09;+	gpio->GPFUP = 0x000000FF;++	gpio->GPGCON = 0xFF40F0C1;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -