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

📄 u-boot-rat.patch

📁 用于mini2440开发板的新版u-boot全部源码
💻 PATCH
📖 第 1 页 / 共 4 页
字号:
++/* 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 */++/*by hugerat,phase 4----------------*/+//#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 B4_Tacs		 	0x0	/*  0clk */+#define B4_Tcos		 	0x3	/*  4clk */+#define B4_Tacc		 	0x7	/* 14clk */+#define B4_Tcoh		 	0x1	/*  1clk */+#define B4_Tah		 	0x3	/*  4clk */+#define B4_Tacp		 	0x6 /*  6clk */+#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 */++/*by hugerat ,phase 1-------------------------*/+/* 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) */+/**************************************/+++# if defined(CONFIG_S3C2440)+#define Trp            0x2    /* 4clk */+#define REFCNT            1012+#else+#define Trp            0x0    /* 2clk */+#define REFCNT            0x0459+#endif+/*-------------------------------------*/++_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 0x30diff -Nurp u-boot-2008.10/board/hugerat/rat2410/Makefile u-boot-rat/board/hugerat/rat2410/Makefile--- u-boot-2008.10/board/hugerat/rat2410/Makefile	1970-01-01 08:00:00.000000000 +0800+++ u-boot-rat/board/hugerat/rat2410/Makefile	2008-12-16 10:33:56.000000000 +0800@@ -0,0 +1,51 @@+#+# (C) Copyright 2000-2006+# 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	= $(obj)lib$(BOARD).a++COBJS	:= rat2410.o nand_read.o flash.o+SOBJS	:= lowlevel_init.o++SRCS	:= $(SOBJS:.o=.S) $(COBJS:.o=.c)+OBJS	:= $(addprefix $(obj),$(COBJS))+SOBJS	:= $(addprefix $(obj),$(SOBJS))++$(LIB):	$(obj).depend $(OBJS) $(SOBJS)+	$(AR) $(ARFLAGS) $@ $(OBJS) $(SOBJS)++clean:+	rm -f $(SOBJS) $(OBJS)++distclean:	clean+	rm -f $(LIB) core *.bak $(obj).depend++#########################################################################++# defines $(obj).depend target+include $(SRCTREE)/rules.mk++sinclude $(obj).depend++#########################################################################diff -Nurp u-boot-2008.10/board/hugerat/rat2410/nand_read.c u-boot-rat/board/hugerat/rat2410/nand_read.c--- u-boot-2008.10/board/hugerat/rat2410/nand_read.c	1970-01-01 08:00:00.000000000 +0800+++ u-boot-rat/board/hugerat/rat2410/nand_read.c	2008-12-16 11:14:08.000000000 +0800@@ -0,0 +1,114 @@+#include <config.h>++#define __REGb(x) (*(volatile unsigned char *)(x))+#define __REGi(x) (*(volatile unsigned int *)(x))+#define NF_BASE 0x4e000000+++#if defined(CONFIG_S3C2440)++#define NFCONF __REGi(NF_BASE + 0x0)+#define NFCONT __REGi(NF_BASE + 0x4)+#define NFCMD __REGb(NF_BASE + 0x8)+#define NFADDR __REGb(NF_BASE + 0xC)+#define NFDATA __REGb(NF_BASE + 0x10)+#define NFSTAT __REGb(NF_BASE + 0x20)++//#define GPDAT聽聽 聽聽聽 聽__REGi(GPIO_CTL_BASE+oGPIO_F+oGPIO_DAT)++#define NAND_CHIP_ENABLE (NFCONT &= ~(1<<1))+#define NAND_CHIP_DISABLE (NFCONT |= (1<<1))+#define NAND_CLEAR_RB (NFSTAT |= (1<<2))+#define NAND_DETECT_RB { while(! (NFSTAT&(1<<2)));}++#define BUSY 4+inline void wait_idle(void) {+	while(!(NFSTAT & BUSY));+	NFSTAT |= BUSY;+}++#define NAND_SECTOR_SIZE 512+#define NAND_BLOCK_MASK (NAND_SECTOR_SIZE - 1)++/* low level nand read function */+int+nand_read_ll(unsigned char *buf, unsigned long start_addr, int size)+{+	int i, j;+	+	if ((start_addr & NAND_BLOCK_MASK) || (size & NAND_BLOCK_MASK)) {+	return -1;	/* invalid alignment */+	}+	+	NAND_CHIP_ENABLE;+		+	for(i=start_addr; i < (start_addr + size);) {+	/* READ0 */+		NAND_CLEAR_RB;	+		NFCMD = 0;	+	+		/* Write Address */+		NFADDR = i & 0xff;+		NFADDR = (i >> 9) & 0xff;+		NFADDR = (i >> 17) & 0xff;+		NFADDR = (i >> 25) & 0xff;+	+		NAND_DETECT_RB;+	+		for(j=0; j < NAND_SECTOR_SIZE; j++, i++) {+		*buf = (NFDATA & 0xff);+		buf++;+		}+	}+	NAND_CHIP_DISABLE;	+	return 0;+} +#endif++#if defined(CONFIG_S3C2410)++#define NFCONF __REGi(NF_BASE + 0x0)+#define NFCMD __REGb(NF_BASE + 0x4)+#define NFADDR __REGb(NF_BASE + 0x8)+#define NFDATA __REGb(NF_BASE + 0xc)+#define NFSTAT __REGb(NF_BASE + 0x10)+#define BUSY 1++#define NAND_SECTOR_SIZE 512+#define NAND_BLOCK_MASK (NAND_SECTOR_SIZE - 1)++inline void wait_idle(void) {+	int i;+	while(!(NFSTAT & BUSY))+	for(i=0; i<10; i++);+}+/* low level nand read function */+int+nand_read_ll(unsigned char *buf, unsigned long start_addr, int size)+{+	int i, j;+	if ((start_addr & NAND_BLOCK_MASK) || (size & NAND_BLOCK_MASK)) {+	return -1;	/* invalid alignment */+	}+	/* chip Enable */+	NFCONF &= ~0x800;+	for(i=0; i<10; i++);+	for(i=start_addr; i < (start_addr + size);) {+	/* READ0 */+	NFCMD = 0;+	/* Write Address */+	NFADDR = i & 0xff;+	NFADDR = (i >> 9) & 0xff;+	NFADDR = (i >> 17) & 0xff;+	NFADDR = (i >> 25) & 0xff;+	wait_idle();+	for(j=0; j < NAND_SECTOR_SIZE; j++, i++) {+	*buf = (NFDATA & 0xff);+	buf++;+	}+	}+	/* chip Disable */+	NFCONF |= 0x800; /* chip disable */+	return 0;+}+#endifdiff -Nurp u-boot-2008.10/board/hugerat/rat2410/rat2410.c u-boot-rat/board/hugerat/rat2410/rat2410.c--- u-boot-2008.10/board/hugerat/rat2410/rat2410.c	1970-01-01 08:00:00.000000000 +0800+++ u-boot-rat/board/hugerat/rat2410/rat2410.c	2008-12-16 11:56:17.000000000 +0800@@ -0,0 +1,178 @@+/*+ * (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 <s3c2410.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 = 202.8MHz */+/*by hugerat ,phase 1-------------*/+#if defined(CONFIG_S3C2410)+/* Fout = 202.8MHz */+#define M_MDIV    0xA1+#define M_PDIV    0x3+#define M_SDIV    0x1+#endif++#if defined(CONFIG_S3C2440)+/* Fout = 405MHz */+#define M_MDIV 0x7f        +#define M_PDIV 0x2+#define M_SDIV 0x1+#endif++/*#define M_MDIV	0xA1+#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+/*by hugerat ,phase 1-----*/+#if defined(CONFIG_S3C2410)+#define U_M_MDIV    0x48+#define U_M_PDIV    0x3+#endif++#if defined(CONFIG_S3C2440)+#define U_M_MDIV 0x38+#define U_M_PDIV 0x2+#endif++/*#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);++	/* set up the I/O ports */+	gpio->GPACON = 0x007FFFFF;+/*by hugerat ,phase 1---------------*/+#if defined(CONFIG_rat2440_LED) +	 gpio->GPBCON = 0x00055555;+#else+	gpio->GPBCON = 0x00044555;+#endif++	/*gpio->GPBCON = 0x00044555;*/+/*-----------------------------------*/+	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 = 0xFF95FFBA;+	gpio->GPGUP = 0x0000FFFF;+	gpio->GPHCON = 0x002AFAAA;+	gpio->GPHUP = 0x000007FF;+/*by hugerat ,phase 1-----------------------------------*/+#if defined(CONFIG_S3C2410)+    /* arch number of SMDK2410-Board */+    gd->bd->bi_arch_number = MACH_TYPE_yangchu2410;++#endif++#if defined(CONFIG_S3C2440)+    /* arch number of S3C2440 -Board */+    gd->bd->bi_arch_number = MACH_TYPE_mini2440 ;+#endif++	/* arch number of SMDK2410-Board */+	//gd->bd->bi_arch_number = MACH_TYPE_SMDK2410;+/*------------------------------------------------------*/+	/* adress of boot parameters */+	gd->bd->bi_boot_params = 0x30000100;++	icache_enable();+	dcache_enable();+/*by hugerat ,phase 1--------------------------------*/+# if defined(CONFIG_rat2440_LED) +    gpio->GPBDAT = 0x180; //hugerat++    //int board_init (void)璁剧疆瀹屾垚鍚庯紝LED1鍜孡ED2浼氫寒璧凤紒++#endif+/*---------------------------------------------------*/+	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;+}diff -Nurp u-boot-2008.10/board/hugerat/rat2410/u-boot.lds u-boot-rat/board/hugerat/rat2410/u-boot.lds--- u-boot-2008.10/board/hugerat/rat2410/u-boot.lds	1970-01-01 08:00:00.000000000 +0800+++ u-boot-rat/board/hugerat/rat2410/u-boot.lds	2008-10-19 03:30:31.000000000 +0800@@ -0,0 +1,57 @@+/*+ * (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)+	  *(.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 = .;+}diff -Nurp u-boot-2008.10/board/hugerat/rat2440/config.mk u-boot-rat/board/hugerat/rat2440/config.mk--- u-boot-2008.10/board/hugerat/rat2440/config.mk	1970-01-01 08:00:00.000000000 +0800+++ u-boot-rat/board/hugerat/rat2440/config.mk	2008-12-16 16:32:08.000000000 +0800@@ -0,0 +1,25 @@+#+# (C) Copyright 2002+# Gary Jennejohn, DENX Software Engineering, <gj@denx.de>

⌨️ 快捷键说明

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