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

📄 uboot-smdk2440.patch

📁 Uboot常用的移植patches, 方便定制移植到s3c2440
💻 PATCH
📖 第 1 页 / 共 3 页
字号:
+#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		 	0x0	/* 2clk */+#define Trc		 	0x3	/* 7clk */+#define Tchr		 	0x2	/* 3clk */+#define REFCNT		 	1113	/* period=15.6us, 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 ! */+	ldr     r0, =SMRDATA+	ldr	r1, _TEXT_BASE+	sub	r0, r0, r1+	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++	/* 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 0x32+    .word 0x30+    .word 0x30Index: u-boot/board/smdk2440/smdk2440.c===================================================================--- /dev/null+++ u-boot/board/smdk2440/smdk2440.c@@ -0,0 +1,152 @@+/*+ * (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 <s3c2440.h>++DECLARE_GLOBAL_DATA_PTR;++#define FCLK_SPEED 1++#if FCLK_SPEED==0		/* Fout = 203MHz, Fin = 12MHz for Audio */+#define M_MDIV	0xC3+#define M_PDIV	0x4+#define M_SDIV	0x1+#elif FCLK_SPEED==1		/* Fout = 399.65MHz */+#define M_MDIV	0x6e+#define M_PDIV	0x3+#define M_SDIV	0x1+#endif++#define USB_CLOCK 1++#if USB_CLOCK==0+#define U_M_MDIV	0xA1+#define U_M_PDIV	0x3+#define U_M_SDIV	0x1+#elif USB_CLOCK==1+#define U_M_MDIV	0x3c+#define U_M_PDIV	0x4+#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);++	/* set up the I/O ports */+	gpio->GPACON = 0x007FFFFF;+	gpio->GPBCON = 0x002a9655;+	gpio->GPBUP = 0x000007FF;+	gpio->GPCCON = 0xAAAAAAAA;+	gpio->GPCUP = 0x0000FFFF;+	gpio->GPDCON = 0xAAAAAAAA;+	gpio->GPDUP = 0x0000FFFF;+	gpio->GPECON = 0xAAAAAAAA;+	gpio->GPEUP = 0x0000FFFF;+	gpio->GPFCON = 0x000055AA;+	gpio->GPFUP = 0x000000FF;+	gpio->GPGCON = 0xFD95FFBA;+	gpio->GPGUP = 0x0000FFFF;+#ifdef CONFIG_SERIAL3+	gpio->GPHCON = 0x002AAAAA;+#else+	gpio->GPHCON = 0x002AFAAA;+#endif+	gpio->GPHUP = 0x000007FF;++	gpio->GPJCON = 0x2AAAAAA;++#if 0+	/* USB Device Part */+	/*GPGCON is reset for USB Device */+	gpio->GPGCON = (gpio->GPGCON & ~(3 << 24)) | (1 << 24); /* Output Mode */+	gpio->GPGUP = gpio->GPGUP | ( 1 << 12);			/* Pull up disable */++	gpio->GPGDAT |= ( 1 << 12) ; +	gpio->GPGDAT &= ~( 1 << 12) ; +	udelay(20000);+	gpio->GPGDAT |= ( 1 << 12) ; +#endif++	/* arch number of SMDK2440-Board */+	gd->bd->bi_arch_number = MACH_TYPE_S3C2440;++	/* adress of boot parameters */+	gd->bd->bi_boot_params = 0x30000100;++	icache_enable();+	dcache_enable();++	return 0;+}++int dram_init (void)+{+	gd->bd->bi_dram[0].start = PHYS_SDRAM_1;+	gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE;++	return 0;+}++/* The sum of all part_size[]s must equal to the NAND size, i.e., 0x4000000.+   "initrd" is sized such that it can hold two uncompressed 16 bit 640*480+   images: 640*480*2*2 = 1228800 < 1245184. */++unsigned int dynpart_size[] = {+    CFG_UBOOT_SIZE, 0x20000, 0x200000, 0xa0000, 0x3d5c000-CFG_UBOOT_SIZE, 0 };+char *dynpart_names[] = {+    "u-boot", "u-boot_env", "kernel", "splash", "rootfs", NULL };++Index: u-boot/board/smdk2440/u-boot.lds===================================================================--- /dev/null+++ u-boot/board/smdk2440/u-boot.lds@@ -0,0 +1,58 @@+/*+ * (C) Copyright 2002+ * Gary Jennejohn, DENX Software Engineering, <gj@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+ */++OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")+/*OUTPUT_FORMAT("elf32-arm", "elf32-arm", "elf32-arm")*/+OUTPUT_ARCH(arm)+ENTRY(_start)+SECTIONS+{+	. = 0x00000000;++	. = ALIGN(4);+	.text      :+	{+	  cpu/arm920t/start.o	(.text)+	  cpu/arm920t/s3c24x0/nand_read.o (.text)+	  *(.text)+	}++	. = ALIGN(4);+	.rodata : { *(.rodata) }++	. = ALIGN(4);+	.data : { *(.data) }++	. = ALIGN(4);+	.got : { *(.got) }++	. = .;+	__u_boot_cmd_start = .;+	.u_boot_cmd : { *(.u_boot_cmd) }+	__u_boot_cmd_end = .;++	. = ALIGN(4);+	__bss_start = .;+	.bss (NOLOAD) : { *(.bss) }+	_end = .;+}Index: u-boot/board/smdk2440/udc.c===================================================================--- /dev/null+++ u-boot/board/smdk2440/udc.c@@ -0,0 +1,23 @@++#include <common.h>+#include <usbdcore.h>+#include <s3c2440.h>++void udc_ctrl(enum usbd_event event, int param)+{+	S3C24X0_GPIO * const gpio = S3C24X0_GetBase_GPIO();++	switch (event) {+	case UDC_CTRL_PULLUP_ENABLE:+		if (param)+			gpio->GPGDAT |= (1 << 12);+		else+			gpio->GPGDAT &= ~(1 << 12);+		break;+	case UDC_CTRL_500mA_ENABLE:+		/* IGNORE */+		break;+	default:+		break;+	}+}Index: u-boot/board/smdk2440/lowlevel_foo.S===================================================================--- /dev/null+++ u-boot/board/smdk2440/lowlevel_foo.S@@ -0,0 +1,82 @@++_start:+	b 	reset+undefvec:+	b	undefvec+swivec:+	b	swivec+pabtvec:+	b	pabtvec+dabtvec:+	b	dabtvec+rsvdvec:+	b	rsvdvec+irqvec:+	b	irqvec+fiqvec:+	b	fiqvec++reset:+	/*+	 * set the cpu to SVC32 mode+	 */+	mrs	r0,cpsr+	bic	r0,r0,#0x1f+	orr	r0,r0,#0xd3+	msr	cpsr,r0++/* turn off the watchdog */+#define pWTCON		0x53000000+#define INTMSK		0x4A000008	/* Interupt-Controller base addresses */+#define INTSUBMSK	0x4A00001C+#define CLKDIVN	0x4C000014	/* clock divisor register */++	ldr     r0, =pWTCON+	mov     r1, #0x0+	str     r1, [r0]++	mov	r1, #0xffffffff+	ldr	r0, =INTMSK+	str	r1, [r0]+	ldr	r1, =0x3ff+	ldr	r0, =INTSUBMSK+	str	r1, [r0]++	/* FCLK:HCLK:PCLK = 1:2:4 */+	/* default FCLK is 120 MHz ! */+	ldr	r0, =CLKDIVN+	mov	r1, #3+	str	r1, [r0]++	bl	cpu_init_crit+	ldr	r0,=TEXT_BASE+	mov	pc, r0++cpu_init_crit:+	/*+	 * flush v4 I/D caches+	 */+	mov	r0, #0+	mcr	p15, 0, r0, c7, c7, 0	/* flush v3/v4 cache */+	mcr	p15, 0, r0, c8, c7, 0	/* flush v4 TLB */++	/*+	 * disable MMU stuff and caches+	 */+	mrc	p15, 0, r0, c1, c0, 0+	bic	r0, r0, #0x00002300	@ clear bits 13, 9:8 (--V- --RS)+	bic	r0, r0, #0x00000087	@ clear bits 7, 2:0 (B--- -CAM)+	orr	r0, r0, #0x00000002	@ set bit 2 (A) Align+	orr	r0, r0, #0x00001000	@ set bit 12 (I) I-Cache+	mcr	p15, 0, r0, c1, c0, 0++	/*+	 * before relocating, we have to setup RAM timing+	 * because memory timing is board-dependend, you will+	 * find a lowlevel_init.S in your board directory.+	 */+	mov	ip, lr+	bl	lowlevel_init+	mov	lr, ip+	mov	pc, lr+Index: u-boot/board/smdk2440/lowlevel_foo.lds===================================================================--- /dev/null+++ u-boot/board/smdk2440/lowlevel_foo.lds@@ -0,0 +1,56 @@+/*+ * (C) Copyright 2002+ * Gary Jennejohn, DENX Software Engineering, <gj@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+ */++OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")+OUTPUT_ARCH(arm)+ENTRY(_start)+SECTIONS+{+	. = 0x00000000;++	. = ALIGN(4);+	.text      :+	{+	  lowlevel_foo.o (.text)+	  *(.text)+	}++	. = ALIGN(4);+	.rodata : { *(.rodata) }++	. = ALIGN(4);+	.data : { *(.data) }++	. = ALIGN(4);+	.got : { *(.got) }++	. = .;+	__u_boot_cmd_start = .;+	.u_boot_cmd : { *(.u_boot_cmd) }+	__u_boot_cmd_end = .;++	. = ALIGN(4);+	__bss_start = .;+	.bss : { *(.bss) }+	_end = .;+}

⌨️ 快捷键说明

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