mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-26 16:56:07 +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>
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Old U-boot compatibility for Walnut
 | |
|  *
 | |
|  * Author: Josh Boyer <jwboyer@linux.vnet.ibm.com>
 | |
|  *
 | |
|  * Copyright 2007 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 "dcr.h"
 | |
| #include "4xx.h"
 | |
| #include "io.h"
 | |
| 
 | |
| BSS_STACK(4096);
 | |
| 
 | |
| static void walnut_flashsel_fixup(void)
 | |
| {
 | |
| 	void *devp, *sram;
 | |
| 	u32 reg_flash[3] = {0x0, 0x0, 0x80000};
 | |
| 	u32 reg_sram[3] = {0x0, 0x0, 0x80000};
 | |
| 	u8 *fpga;
 | |
| 	u8 fpga_brds1 = 0x0;
 | |
| 
 | |
| 	devp = finddevice("/plb/ebc/fpga");
 | |
| 	if (!devp)
 | |
| 		fatal("Couldn't locate FPGA node\n\r");
 | |
| 
 | |
| 	if (getprop(devp, "virtual-reg", &fpga, sizeof(fpga)) != sizeof(fpga))
 | |
| 		fatal("no virtual-reg property\n\r");
 | |
| 
 | |
| 	fpga_brds1 = in_8(fpga);
 | |
| 
 | |
| 	devp = finddevice("/plb/ebc/flash");
 | |
| 	if (!devp)
 | |
| 		fatal("Couldn't locate flash node\n\r");
 | |
| 
 | |
| 	if (getprop(devp, "reg", reg_flash, sizeof(reg_flash)) != sizeof(reg_flash))
 | |
| 		fatal("flash reg property has unexpected size\n\r");
 | |
| 
 | |
| 	sram = finddevice("/plb/ebc/sram");
 | |
| 	if (!sram)
 | |
| 		fatal("Couldn't locate sram node\n\r");
 | |
| 
 | |
| 	if (getprop(sram, "reg", reg_sram, sizeof(reg_sram)) != sizeof(reg_sram))
 | |
| 		fatal("sram reg property has unexpected size\n\r");
 | |
| 
 | |
| 	if (fpga_brds1 & 0x1) {
 | |
| 		reg_flash[1] ^= 0x80000;
 | |
| 		reg_sram[1] ^= 0x80000;
 | |
| 	}
 | |
| 
 | |
| 	setprop(devp, "reg", reg_flash, sizeof(reg_flash));
 | |
| 	setprop(sram, "reg", reg_sram, sizeof(reg_sram));
 | |
| }
 | |
| 
 | |
| #define WALNUT_OPENBIOS_MAC_OFF 0xfffffe0b
 | |
| static void walnut_fixups(void)
 | |
| {
 | |
| 	ibm4xx_sdram_fixup_memsize();
 | |
| 	ibm405gp_fixup_clocks(33330000, 0xa8c000);
 | |
| 	ibm4xx_quiesce_eth((u32 *)0xef600800, NULL);
 | |
| 	ibm4xx_fixup_ebc_ranges("/plb/ebc");
 | |
| 	walnut_flashsel_fixup();
 | |
| 	dt_fixup_mac_address_by_alias("ethernet0", (u8 *) WALNUT_OPENBIOS_MAC_OFF);
 | |
| }
 | |
| 
 | |
| void platform_init(void)
 | |
| {
 | |
| 	unsigned long end_of_ram = 0x2000000;
 | |
| 	unsigned long avail_ram = end_of_ram - (unsigned long) _end;
 | |
| 
 | |
| 	simple_alloc_init(_end, avail_ram, 32, 32);
 | |
| 	platform_ops.fixups = walnut_fixups;
 | |
| 	platform_ops.exit = ibm40x_dbcr_reset;
 | |
| 	fdt_init(_dtb_start);
 | |
| 	serial_console_init();
 | |
| }
 |