mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 06:56:05 +00:00 
			
		
		
		
	 ecc6cd73b7
			
		
	
	
		ecc6cd73b7
		
	
	
	
	
		
			
			This patch alters the bootwrapper for a number of machines (roubhly all 4xx based cuboot or treeboot platforms) to use aliases instead of the linux,network-index hack to work out which MAC address to attach to which ethernet device node. The now obsolete linux,network-index properties are removed from the corresponding device trees. This won't break backwards compatiblity, because in cases where this fixup code is relevant, the device tree is part of the kernel image. The references to linux,network-index are removed from booting-without-of.txt. Not only is it now deprecated, but as a hack applicable only when the device tree blob and fixup code were in the same image, this property never belonged in booting-without-of.txt which describes the interface between the kernel and firmware or bootloaders which produce a device tree. By the time the device tree reaches the kernel, all the MAC addresses must be fully filled in. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Josh Boyer <jwboyer@linux.vnet.ibm.com>
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Old U-boot compatibility for Taishan
 | |
|  *
 | |
|  * Author: Hugh Blemings <hugh@au.ibm.com>
 | |
|  *
 | |
|  * Copyright 2007 Hugh Blemings, IBM Corporation.
 | |
|  *   Based on cuboot-ebony.c which is:
 | |
|  * Copyright 2007 David Gibson, IBM Corporation.
 | |
|  *   Based on cuboot-83xx.c, which is:
 | |
|  * Copyright (c) 2007 Freescale Semiconductor, Inc.
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or modify it
 | |
|  * under the terms of the GNU General Public License version 2 as published
 | |
|  * by the Free Software Foundation.
 | |
|  */
 | |
| 
 | |
| #include "ops.h"
 | |
| #include "stdio.h"
 | |
| #include "cuboot.h"
 | |
| #include "reg.h"
 | |
| #include "dcr.h"
 | |
| #include "4xx.h"
 | |
| 
 | |
| #define TARGET_4xx
 | |
| #define TARGET_44x
 | |
| #define TARGET_440GX
 | |
| #include "ppcboot.h"
 | |
| 
 | |
| static bd_t bd;
 | |
| 
 | |
| BSS_STACK(4096);
 | |
| 
 | |
| static void taishan_fixups(void)
 | |
| {
 | |
| 	/* FIXME: sysclk should be derived by reading the FPGA
 | |
| 	   registers */
 | |
| 	unsigned long sysclk = 33000000;
 | |
| 
 | |
| 	ibm440gx_fixup_clocks(sysclk, 6 * 1843200, 25000000);
 | |
| 
 | |
| 	ibm4xx_sdram_fixup_memsize();
 | |
| 
 | |
| 	dt_fixup_mac_address_by_alias("ethernet0", bd.bi_enetaddr);
 | |
| 	dt_fixup_mac_address_by_alias("ethernet1", bd.bi_enet1addr);
 | |
| 
 | |
| 	ibm4xx_fixup_ebc_ranges("/plb/opb/ebc");
 | |
| }
 | |
| 
 | |
| void platform_init(unsigned long r3, unsigned long r4, unsigned long r5,
 | |
| 		   unsigned long r6, unsigned long r7)
 | |
| {
 | |
| 	CUBOOT_INIT();
 | |
| 
 | |
| 	platform_ops.fixups = taishan_fixups;
 | |
| 	fdt_init(_dtb_start);
 | |
| 	serial_console_init();
 | |
| }
 |