mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-10 03:09:08 +08:00
update bcm963xx patch and add some binary compatibility hacks (incomplete)
SVN-Revision: 4691
This commit is contained in:
parent
9e9a0a4ca0
commit
b6a32036a8
@ -586,8 +586,8 @@ diff -urN linux.old/arch/mips/bcm963xx/bcm63xx_led.c linux.dev/arch/mips/bcm963x
|
||||
+
|
||||
diff -urN linux.old/arch/mips/bcm963xx/board.c linux.dev/arch/mips/bcm963xx/board.c
|
||||
--- linux.old/arch/mips/bcm963xx/board.c 1970-01-01 01:00:00.000000000 +0100
|
||||
+++ linux.dev/arch/mips/bcm963xx/board.c 2006-08-25 15:16:26.000000000 +0200
|
||||
@@ -0,0 +1,555 @@
|
||||
+++ linux.dev/arch/mips/bcm963xx/board.c 2006-08-27 21:02:04.000000000 +0200
|
||||
@@ -0,0 +1,559 @@
|
||||
+/*
|
||||
+<:copyright-gpl
|
||||
+ Copyright 2002 Broadcom Corp. All Rights Reserved.
|
||||
@ -760,17 +760,21 @@ diff -urN linux.old/arch/mips/bcm963xx/board.c linux.dev/arch/mips/bcm963xx/boar
|
||||
+ /* CMO -- Fix le problème avec les adresses mac que l'on n'arrive pas
|
||||
+ * * à relire plusieurs fois */
|
||||
+ /* inv_xde */
|
||||
+#if 0
|
||||
+ if (boot_loader_type == BOOT_CFE)
|
||||
+ memcpy( pucaMacAddr, g_pNvramInfo->ucaBaseMacAddr,
|
||||
+ NVRAM_MAC_ADDRESS_LEN );
|
||||
+ else {
|
||||
+#endif
|
||||
+ pucaMacAddr[0] = 0x00;
|
||||
+ pucaMacAddr[1] = 0x07;
|
||||
+ pucaMacAddr[2] = 0x3A;
|
||||
+ pucaMacAddr[3] = 0xFF;
|
||||
+ pucaMacAddr[4] = 0xFF;
|
||||
+ pucaMacAddr[5] = 0xFF;
|
||||
+#if 0
|
||||
+ }
|
||||
+#endif
|
||||
+
|
||||
+ return nRet;
|
||||
+} /* kerSysGetMacAddr */
|
||||
@ -6918,8 +6922,8 @@ diff -urN linux.old/arch/mips/bcm963xx/Makefile linux.dev/arch/mips/bcm963xx/Mak
|
||||
+
|
||||
diff -urN linux.old/arch/mips/bcm963xx/prom.c linux.dev/arch/mips/bcm963xx/prom.c
|
||||
--- linux.old/arch/mips/bcm963xx/prom.c 1970-01-01 01:00:00.000000000 +0100
|
||||
+++ linux.dev/arch/mips/bcm963xx/prom.c 2006-08-25 01:49:57.000000000 +0200
|
||||
@@ -0,0 +1,128 @@
|
||||
+++ linux.dev/arch/mips/bcm963xx/prom.c 2006-08-27 21:02:04.000000000 +0200
|
||||
@@ -0,0 +1,130 @@
|
||||
+/*
|
||||
+<:copyright-gpl
|
||||
+ Copyright 2004 Broadcom Corp. All Rights Reserved.
|
||||
@ -7037,6 +7041,8 @@ diff -urN linux.old/arch/mips/bcm963xx/prom.c linux.dev/arch/mips/bcm963xx/prom.
|
||||
+
|
||||
+ mips_machgroup = MACH_GROUP_BRCM;
|
||||
+ mips_machtype = MACH_BCM;
|
||||
+
|
||||
+ BpSetBoardId("96348GW-10");
|
||||
+}
|
||||
+
|
||||
+/* --------------------------------------------------------------------------
|
||||
@ -9626,3 +9632,4 @@ diff -urN linux.old/include/asm-mips/module.h linux.dev/include/asm-mips/module.
|
||||
#else
|
||||
#error MODULE_PROC_FAMILY undefined for your processor configuration
|
||||
#endif
|
||||
|
||||
|
267
openwrt/target/linux/brcm63xx-2.6/patches/100-binary_hacks.patch
Normal file
267
openwrt/target/linux/brcm63xx-2.6/patches/100-binary_hacks.patch
Normal file
@ -0,0 +1,267 @@
|
||||
diff -urN linux.old/include/asm-mips/cpu-info.h linux.dev/include/asm-mips/cpu-info.h
|
||||
--- linux.old/include/asm-mips/cpu-info.h 2006-06-18 03:49:35.000000000 +0200
|
||||
+++ linux.dev/include/asm-mips/cpu-info.h 2006-08-27 21:02:04.000000000 +0200
|
||||
@@ -63,7 +63,6 @@
|
||||
* Capability and feature descriptor structure for MIPS CPU
|
||||
*/
|
||||
unsigned long options;
|
||||
- unsigned long ases;
|
||||
unsigned int processor_id;
|
||||
unsigned int fpu_id;
|
||||
unsigned int cputype;
|
||||
@@ -84,6 +83,7 @@
|
||||
int tc_id; /* Thread Context number */
|
||||
#endif /* CONFIG_MIPS_MT */
|
||||
void *data; /* Additional data */
|
||||
+ unsigned long ases;
|
||||
} __attribute__((aligned(SMP_CACHE_BYTES)));
|
||||
|
||||
extern struct cpuinfo_mips cpu_data[];
|
||||
|
||||
diff -urN linux.old/include/linux/netdevice.h linux.dev/include/linux/netdevice.h
|
||||
--- linux.old/include/linux/netdevice.h 2006-06-18 03:49:35.000000000 +0200
|
||||
+++ linux.dev/include/linux/netdevice.h 2006-08-27 21:02:04.000000000 +0200
|
||||
@@ -266,8 +266,6 @@
|
||||
* the interface.
|
||||
*/
|
||||
char name[IFNAMSIZ];
|
||||
- /* device name hash chain */
|
||||
- struct hlist_node name_hlist;
|
||||
|
||||
/*
|
||||
* I/O specific fields
|
||||
@@ -295,22 +293,6 @@
|
||||
|
||||
/* ------- Fields preinitialized in Space.c finish here ------- */
|
||||
|
||||
- /* Net device features */
|
||||
- unsigned long features;
|
||||
-#define NETIF_F_SG 1 /* Scatter/gather IO. */
|
||||
-#define NETIF_F_IP_CSUM 2 /* Can checksum only TCP/UDP over IPv4. */
|
||||
-#define NETIF_F_NO_CSUM 4 /* Does not require checksum. F.e. loopack. */
|
||||
-#define NETIF_F_HW_CSUM 8 /* Can checksum all the packets. */
|
||||
-#define NETIF_F_HIGHDMA 32 /* Can DMA to high memory. */
|
||||
-#define NETIF_F_FRAGLIST 64 /* Scatter/gather IO. */
|
||||
-#define NETIF_F_HW_VLAN_TX 128 /* Transmit VLAN hw acceleration */
|
||||
-#define NETIF_F_HW_VLAN_RX 256 /* Receive VLAN hw acceleration */
|
||||
-#define NETIF_F_HW_VLAN_FILTER 512 /* Receive filtering on VLAN */
|
||||
-#define NETIF_F_VLAN_CHALLENGED 1024 /* Device cannot handle VLAN packets */
|
||||
-#define NETIF_F_TSO 2048 /* Can offload TCP/IP segmentation */
|
||||
-#define NETIF_F_LLTX 4096 /* LockLess TX */
|
||||
-#define NETIF_F_UFO 8192 /* Can offload UDP Large Send*/
|
||||
-
|
||||
struct net_device *next_sched;
|
||||
|
||||
/* Interface index. Unique device identifier */
|
||||
@@ -324,8 +306,6 @@
|
||||
/* List of functions to handle Wireless Extensions (instead of ioctl).
|
||||
* See <net/iw_handler.h> for details. Jean II */
|
||||
const struct iw_handler_def * wireless_handlers;
|
||||
- /* Instance data managed by the core of Wireless Extensions. */
|
||||
- struct iw_public_data * wireless_data;
|
||||
|
||||
struct ethtool_ops *ethtool_ops;
|
||||
|
||||
@@ -335,33 +315,37 @@
|
||||
* will (read: may be cleaned up at will).
|
||||
*/
|
||||
|
||||
+ /* These may be needed for future network-power-down code. */
|
||||
+ unsigned long trans_start; /* Time (in jiffies) of last Tx */
|
||||
+ unsigned long last_rx; /* Time of last Rx */
|
||||
|
||||
- unsigned int flags; /* interface flags (a la BSD) */
|
||||
+ unsigned short flags; /* interface flags (a la BSD) */
|
||||
unsigned short gflags;
|
||||
unsigned short priv_flags; /* Like 'flags' but invisible to userspace. */
|
||||
- unsigned short padded; /* How much padding added by alloc_netdev() */
|
||||
-
|
||||
- unsigned char operstate; /* RFC2863 operstate */
|
||||
- unsigned char link_mode; /* mapping policy to operstate */
|
||||
+ unsigned short __useless_padding;
|
||||
|
||||
unsigned mtu; /* interface MTU value */
|
||||
unsigned short type; /* interface hardware type */
|
||||
unsigned short hard_header_len; /* hardware hdr length */
|
||||
+ void *priv; /* pointer to private data */
|
||||
|
||||
struct net_device *master; /* Pointer to master device of a group,
|
||||
* which this device is member of.
|
||||
*/
|
||||
|
||||
/* Interface address info. */
|
||||
- unsigned char perm_addr[MAX_ADDR_LEN]; /* permanent hw address */
|
||||
+ unsigned char broadcast[MAX_ADDR_LEN]; /* hw bcast add */
|
||||
+ unsigned char dev_addr[MAX_ADDR_LEN]; /* hw address, (before bcast
|
||||
+ because most packets are unicast) */
|
||||
unsigned char addr_len; /* hardware address length */
|
||||
- unsigned short dev_id; /* for shared network cards */
|
||||
|
||||
struct dev_mc_list *mc_list; /* Multicast mac addresses */
|
||||
int mc_count; /* Number of installed mcasts */
|
||||
int promiscuity;
|
||||
int allmulti;
|
||||
|
||||
+ int watchdog_timeo; /* used by dev_watchdog() */
|
||||
+ struct timer_list watchdog_timer;
|
||||
|
||||
/* Protocol specific pointers */
|
||||
|
||||
@@ -378,29 +362,17 @@
|
||||
struct list_head poll_list ____cacheline_aligned_in_smp;
|
||||
/* Link to poll list */
|
||||
|
||||
- int (*poll) (struct net_device *dev, int *quota);
|
||||
int quota;
|
||||
int weight;
|
||||
- unsigned long last_rx; /* Time of last Rx */
|
||||
/* Interface address info used in eth_type_trans() */
|
||||
- unsigned char dev_addr[MAX_ADDR_LEN]; /* hw address, (before bcast
|
||||
- because most packets are unicast) */
|
||||
-
|
||||
- unsigned char broadcast[MAX_ADDR_LEN]; /* hw bcast add */
|
||||
-
|
||||
-/*
|
||||
- * Cache line mostly used on queue transmit path (qdisc)
|
||||
- */
|
||||
- /* device queue lock */
|
||||
- spinlock_t queue_lock ____cacheline_aligned_in_smp;
|
||||
struct Qdisc *qdisc;
|
||||
struct Qdisc *qdisc_sleeping;
|
||||
+ struct Qdisc *qdisc_ingress;
|
||||
struct list_head qdisc_list;
|
||||
unsigned long tx_queue_len; /* Max frames per queue allowed */
|
||||
|
||||
/* ingress path synchronizer */
|
||||
spinlock_t ingress_lock;
|
||||
- struct Qdisc *qdisc_ingress;
|
||||
|
||||
/*
|
||||
* One part is mostly used on xmit path (device)
|
||||
@@ -411,16 +383,13 @@
|
||||
if nobody entered there.
|
||||
*/
|
||||
int xmit_lock_owner;
|
||||
- void *priv; /* pointer to private data */
|
||||
- int (*hard_start_xmit) (struct sk_buff *skb,
|
||||
- struct net_device *dev);
|
||||
- /* These may be needed for future network-power-down code. */
|
||||
- unsigned long trans_start; /* Time (in jiffies) of last Tx */
|
||||
-
|
||||
- int watchdog_timeo; /* used by dev_watchdog() */
|
||||
- struct timer_list watchdog_timer;
|
||||
|
||||
/*
|
||||
+ * Cache line mostly used on queue transmit path (qdisc)
|
||||
+ */
|
||||
+ /* device queue lock */
|
||||
+ spinlock_t queue_lock ____cacheline_aligned_in_smp;
|
||||
+/*
|
||||
* refcnt is a very hot point, so align it on SMP
|
||||
*/
|
||||
/* Number of references to this device */
|
||||
@@ -428,6 +397,8 @@
|
||||
|
||||
/* delayed register/unregister */
|
||||
struct list_head todo_list;
|
||||
+ /* device name hash chain */
|
||||
+ struct hlist_node name_hlist;
|
||||
/* device index hash chain */
|
||||
struct hlist_node index_hlist;
|
||||
|
||||
@@ -439,6 +410,22 @@
|
||||
NETREG_RELEASED, /* called free_netdev */
|
||||
} reg_state;
|
||||
|
||||
+ /* Net device features */
|
||||
+ unsigned int features;
|
||||
+#define NETIF_F_SG 1 /* Scatter/gather IO. */
|
||||
+#define NETIF_F_IP_CSUM 2 /* Can checksum only TCP/UDP over IPv4. */
|
||||
+#define NETIF_F_NO_CSUM 4 /* Does not require checksum. F.e. loopack. */
|
||||
+#define NETIF_F_HW_CSUM 8 /* Can checksum all the packets. */
|
||||
+#define NETIF_F_HIGHDMA 32 /* Can DMA to high memory. */
|
||||
+#define NETIF_F_FRAGLIST 64 /* Scatter/gather IO. */
|
||||
+#define NETIF_F_HW_VLAN_TX 128 /* Transmit VLAN hw acceleration */
|
||||
+#define NETIF_F_HW_VLAN_RX 256 /* Receive VLAN hw acceleration */
|
||||
+#define NETIF_F_HW_VLAN_FILTER 512 /* Receive filtering on VLAN */
|
||||
+#define NETIF_F_VLAN_CHALLENGED 1024 /* Device cannot handle VLAN packets */
|
||||
+#define NETIF_F_TSO 2048 /* Can offload TCP/IP segmentation */
|
||||
+#define NETIF_F_LLTX 4096 /* LockLess TX */
|
||||
+#define NETIF_F_UFO 8192 /* Can offload UDP Large Send*/
|
||||
+
|
||||
/* Called after device is detached from network. */
|
||||
void (*uninit)(struct net_device *dev);
|
||||
/* Called after last user reference disappears. */
|
||||
@@ -447,7 +434,10 @@
|
||||
/* Pointers to interface service routines. */
|
||||
int (*open)(struct net_device *dev);
|
||||
int (*stop)(struct net_device *dev);
|
||||
+ int (*hard_start_xmit) (struct sk_buff *skb,
|
||||
+ struct net_device *dev);
|
||||
#define HAVE_NETDEV_POLL
|
||||
+ int (*poll) (struct net_device *dev, int *quota);
|
||||
int (*hard_header) (struct sk_buff *skb,
|
||||
struct net_device *dev,
|
||||
unsigned short type,
|
||||
@@ -490,6 +480,7 @@
|
||||
int (*neigh_setup)(struct net_device *dev, struct neigh_parms *);
|
||||
#ifdef CONFIG_NETPOLL
|
||||
struct netpoll_info *npinfo;
|
||||
+ int netpoll_rx;
|
||||
#endif
|
||||
#ifdef CONFIG_NET_POLL_CONTROLLER
|
||||
void (*poll_controller)(struct net_device *dev);
|
||||
@@ -507,6 +498,17 @@
|
||||
struct class_device class_dev;
|
||||
/* space for optional statistics and wireless sysfs groups */
|
||||
struct attribute_group *sysfs_groups[3];
|
||||
+
|
||||
+ unsigned char operstate; /* RFC2863 operstate */
|
||||
+ unsigned char link_mode; /* mapping policy to operstate */
|
||||
+ unsigned short dev_id; /* for shared network cards */
|
||||
+
|
||||
+ /* Instance data managed by the core of Wireless Extensions. */
|
||||
+ struct iw_public_data * wireless_data;
|
||||
+
|
||||
+ unsigned char perm_addr[MAX_ADDR_LEN]; /* permanent hw address */
|
||||
+
|
||||
+ unsigned short padded; /* How much padding added by alloc_netdev() */
|
||||
};
|
||||
|
||||
#define NETDEV_ALIGN 32
|
||||
@@ -587,9 +589,10 @@
|
||||
|
||||
struct softnet_data
|
||||
{
|
||||
- struct net_device *output_queue;
|
||||
+ int useless_padding[3];
|
||||
struct sk_buff_head input_pkt_queue;
|
||||
struct list_head poll_list;
|
||||
+ struct net_device *output_queue;
|
||||
struct sk_buff *completion_queue;
|
||||
|
||||
struct net_device backlog_dev; /* Sorry. 8) */
|
||||
diff -urN linux.old/include/linux/timer.h linux.dev/include/linux/timer.h
|
||||
--- linux.old/include/linux/timer.h 2006-06-18 03:49:35.000000000 +0200
|
||||
+++ linux.dev/include/linux/timer.h 2006-08-27 21:02:04.000000000 +0200
|
||||
@@ -12,6 +12,9 @@
|
||||
struct list_head entry;
|
||||
unsigned long expires;
|
||||
|
||||
+ spinlock_t lock;
|
||||
+ unsigned long magic;
|
||||
+
|
||||
void (*function)(unsigned long);
|
||||
unsigned long data;
|
||||
|
||||
diff -urN linux.old/kernel/timer.c linux.dev/kernel/timer.c
|
||||
--- linux.old/kernel/timer.c 2006-06-18 03:49:35.000000000 +0200
|
||||
+++ linux.dev/kernel/timer.c 2006-08-27 21:02:04.000000000 +0200
|
||||
@@ -147,6 +147,7 @@
|
||||
{
|
||||
timer->entry.next = NULL;
|
||||
timer->base = per_cpu(tvec_bases, raw_smp_processor_id());
|
||||
+ spin_lock_init(&timer->lock);
|
||||
}
|
||||
EXPORT_SYMBOL(init_timer);
|
||||
|
Loading…
x
Reference in New Issue
Block a user