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

📄 uboot-hxd8.patch

📁 Uboot常用的移植patches, 方便定制移植到s3c2440
💻 PATCH
📖 第 1 页 / 共 3 页
字号:
Patch to add HXD8 supportIndex: u-boot/Makefile===================================================================--- u-boot.orig/Makefile+++ u-boot/Makefile@@ -2340,6 +2340,9 @@ qt2410_config	:	unconfig 	@./mkconfig $(@:_config=) arm arm920t qt2410 NULL s3c24x0 +hxd8_config	:	unconfig+	@$(MKCONFIG) $(@:_config=) arm arm920t hxd8 NULL s3c24x0+ scb9328_config	:	unconfig 	@$(MKCONFIG) $(@:_config=) arm arm920t scb9328 NULL imx Index: u-boot/board/hxd8/Makefile===================================================================--- /dev/null+++ u-boot/board/hxd8/Makefile@@ -0,0 +1,65 @@+#+# (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	:= hxd8.o udc.o pcf50606.o+SOBJS	:= lowlevel_init.o++SRCS	:= $(SOBJS:.o=.S) $(COBJS:.o=.c)+OBJS	:= $(addprefix $(obj),$(COBJS))+SOBJS	:= $(addprefix $(obj),$(SOBJS))++all:	$(LIB) lowevel_foo.bin++$(LIB):	$(obj).depend $(OBJS) $(SOBJS)+	$(AR) $(ARFLAGS) $@ $(OBJS) $(SOBJS)++lowlevel_foo.o:	lowlevel_foo.S+	$(CC) -c -DTEXT_BASE=0x33F80000 -march=armv4 \+	  -o lowlevel_foo.o lowlevel_foo.S++lowlevel_foo:	lowlevel_foo.o lowlevel_init.o lowlevel_foo.lds+	$(LD) -T ./lowlevel_foo.lds -Ttext 0x33f80000 -Bstatic \+	  lowlevel_init.o lowlevel_foo.o -o lowlevel_foo++lowevel_foo.bin:	lowlevel_foo+	$(CROSS_COMPILE)objcopy --gap-fill=0xff -O binary \+	  lowlevel_foo lowlevel_foo.bin++clean:+	rm -f $(SOBJS) $(OBJS)++distclean:	clean+	rm -f $(LIB) core *.bak .depend++#########################################################################++# defines $(obj).depend target+include $(SRCTREE)/rules.mk++sinclude $(obj).depend++#########################################################################Index: u-boot/board/hxd8/hxd8.c===================================================================--- /dev/null+++ u-boot/board/hxd8/hxd8.c@@ -0,0 +1,189 @@+/*+ * (C) Copyright 2007 by OpenMoko, Inc.+ * Author: Harald Welte <laforge@openmoko.org>+ *+ * (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 <nand.h>+#include <pcf50606.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+#if 0+#define M_MDIV	0x6e	/* Fout = 399.65MHz */+#define M_PDIV	0x3+#define M_SDIV	0x1+#else+#define M_MDIV	0x61	/* Fout = 296.35MHz due to wrong PLL capacitors */+#define M_PDIV	0x1+#define M_SDIV	0x2+#endif+#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 = 0x005E0FFE;+	gpio->GPADAT = 0x0001C000;+	gpio->GPBCON = 0x00045542;+	gpio->GPBUP = 0x000007FF;+	gpio->GPCCON = 0xAAAA02A9;+	gpio->GPCUP = 0x0000FFFF;+	gpio->GPDCON = 0xAAAAAAAA;+	gpio->GPDUP = 0x0000FFFF;+	gpio->GPECON = 0xAAAAAAAA;+	gpio->GPEUP = 0x0000FFFF;+	gpio->GPFCON = 0x0000AAA9;+	gpio->GPFUP = 0x000000FF;+	gpio->GPGCON = 0x027D0316;+	gpio->GPGUP = 0x0000FFFF;+	gpio->GPHCON = 0x0014AAAA;+	gpio->GPHUP = 0x000007FF;+	gpio->GPJCON = 0x00000000;++	/* USB CHG enable */+	gpio->GPGDAT |= ( 1 << 11);+#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_HXD8;++	/* adress of boot parameters */+	gd->bd->bi_boot_params = 0x30000100;++	icache_enable();+	dcache_enable();++	return 0;+}++void board_video_init(GraphicDevice *pGD)+{+	S3C24X0_LCD * const lcd = S3C24X0_GetBase_LCD();++	lcd->LCDCON1 = 0x0000057b;+	lcd->LCDCON2 = 0x0143c049;+	lcd->LCDCON3 = 0x0009df01;+	lcd->LCDCON4 = 0x00000028;+	lcd->LCDCON5 = 0x00000b08;++	lcd->TPAL = 0x01202020;++	//lcd->LCDCON5 |= (0x01 << 3);+}++int board_late_init(void)+{+	/* Initialize the Power Management Unit with a safe register set */+	pcf50606_init();++	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;+}++u_int32_t get_board_rev(void)+{+	return 0x00000110;+}++/* 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, 0x3fd00000, 0 };+char *dynpart_names[] = {+    "u-boot", "u-boot_env", "kernel", "splash", "rootfs", NULL };+Index: u-boot/board/hxd8/lowlevel_init.S===================================================================--- /dev/null+++ u-boot/board/hxd8/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 FIC HXD8 by Harald Welte <laforge@openmoko.org>+ * (C) Copyright 2007 by OpenMoko, Inc.+ *+ * 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 */

⌨️ 快捷键说明

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