All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 3/3] netxen: qlogic ethernet : Fix Endian Bug.
  2012-03-02 15:23           ` santosh nayak
@ 2012-03-03 15:59 ` santosh nayak
  -1 siblings, 0 replies; 73+ messages in thread
From: santosh nayak @ 2012-03-03 15:47 UTC (permalink / raw)
  To: sony.chacko
  Cc: rajesh.borundia, netdev, linux-kernel, kernel-janitors,
	Santosh Nayak

From: Santosh Nayak <santoshprasadnayak@gmail.com>

Fix endian bug.

Signed-off-by: Santosh Nayak <santoshprasadnayak@gmail.com>
---
 drivers/net/ethernet/qlogic/netxen/netxen_nic.h    |    4 ++--
 drivers/net/ethernet/qlogic/netxen/netxen_nic_hw.c |   12 +++++++-----
 .../net/ethernet/qlogic/netxen/netxen_nic_main.c   |    2 +-
 3 files changed, 10 insertions(+), 8 deletions(-)

diff --git a/drivers/net/ethernet/qlogic/netxen/netxen_nic.h b/drivers/net/ethernet/qlogic/netxen/netxen_nic.h
index 2eeac32..b5de8a7 100644
--- a/drivers/net/ethernet/qlogic/netxen/netxen_nic.h
+++ b/drivers/net/ethernet/qlogic/netxen/netxen_nic.h
@@ -954,7 +954,7 @@ typedef struct nx_mac_list_s {
 
 struct nx_vlan_ip_list {
 	struct list_head list;
-	u32 ip_addr;
+	__be32 ip_addr;
 };
 
 /*
@@ -1780,7 +1780,7 @@ int netxen_process_rcv_ring(struct nx_host_sds_ring *sds_ring, int max);
 void netxen_p3_free_mac_list(struct netxen_adapter *adapter);
 int netxen_config_intr_coalesce(struct netxen_adapter *adapter);
 int netxen_config_rss(struct netxen_adapter *adapter, int enable);
-int netxen_config_ipaddr(struct netxen_adapter *adapter, u32 ip, int cmd);
+int netxen_config_ipaddr(struct netxen_adapter *adapter, __be32 ip, int cmd);
 int netxen_linkevent_request(struct netxen_adapter *adapter, int enable);
 void netxen_advert_link_change(struct netxen_adapter *adapter, int linkup);
 void netxen_pci_camqm_read_2M(struct netxen_adapter *, u64, u64 *);
diff --git a/drivers/net/ethernet/qlogic/netxen/netxen_nic_hw.c b/drivers/net/ethernet/qlogic/netxen/netxen_nic_hw.c
index 6f37470..0f81287 100644
--- a/drivers/net/ethernet/qlogic/netxen/netxen_nic_hw.c
+++ b/drivers/net/ethernet/qlogic/netxen/netxen_nic_hw.c
@@ -909,10 +909,11 @@ int netxen_config_rss(struct netxen_adapter *adapter, int enable)
 	return rv;
 }
 
-int netxen_config_ipaddr(struct netxen_adapter *adapter, u32 ip, int cmd)
+int netxen_config_ipaddr(struct netxen_adapter *adapter, __be32 ip, int cmd)
 {
 	nx_nic_req_t req;
 	u64 word;
+	u64 ip_addr;
 	int rv;
 
 	memset(&req, 0, sizeof(nx_nic_req_t));
@@ -922,7 +923,8 @@ int netxen_config_ipaddr(struct netxen_adapter *adapter, u32 ip, int cmd)
 	req.req_hdr = cpu_to_le64(word);
 
 	req.words[0] = cpu_to_le64(cmd);
-	req.words[1] = cpu_to_le64(ip);
+	ip_addr = be32_to_cpu(ip);
+	*(__be64 *)&req.words[1] = cpu_to_be64(ip_addr);
 
 	rv = netxen_send_cmd_descs(adapter, (struct cmd_desc_type0 *)&req, 1);
 	if (rv != 0) {
@@ -1050,7 +1052,7 @@ int netxen_get_flash_mac_addr(struct netxen_adapter *adapter, u64 *mac)
 	if (netxen_get_flash_block(adapter, offset, sizeof(u64), pmac) == -1)
 		return -1;
 
-	if (*mac == cpu_to_le64(~0ULL)) {
+	if (*mac == ~0ULL) {
 
 		offset = NX_OLD_MAC_ADDR_OFFSET +
 			(adapter->portnum * sizeof(u64));
@@ -1059,7 +1061,7 @@ int netxen_get_flash_mac_addr(struct netxen_adapter *adapter, u64 *mac)
 					offset, sizeof(u64), pmac) == -1)
 			return -1;
 
-		if (*mac == cpu_to_le64(~0ULL))
+		if (*mac == ~0ULL)
 			return -1;
 	}
 	return 0;
@@ -2178,7 +2180,7 @@ lock_try:
 		NX_WR_DUMP_REG(FLASH_ROM_WINDOW, adapter->ahw.pci_base0, waddr);
 		raddr = FLASH_ROM_DATA + (fl_addr & 0x0000FFFF);
 		NX_RD_DUMP_REG(raddr, adapter->ahw.pci_base0, &val);
-		*data_buff++ = cpu_to_le32(val);
+		*data_buff++ = val;
 		fl_addr += sizeof(val);
 	}
 	readl((void __iomem *)(adapter->ahw.pci_base0 + NX_FLASH_SEM2_ULK));
diff --git a/drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c b/drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c
index 8dc4a134..70783b4 100644
--- a/drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c
+++ b/drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c
@@ -818,7 +818,7 @@ netxen_check_options(struct netxen_adapter *adapter)
 			adapter->driver_mismatch = 1;
 			return;
 		}
-		ptr32[i] = cpu_to_le32(val);
+		ptr32[i] = val;
 		offset += sizeof(u32);
 	}
 
-- 
1.7.4.4


^ permalink raw reply related	[flat|nested] 73+ messages in thread

end of thread, other threads:[~2012-03-15  9:31 UTC | newest]

Thread overview: 73+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-03-03 15:47 [PATCH 3/3] netxen: qlogic ethernet : Fix Endian Bug santosh nayak
2012-03-03 15:59 ` santosh nayak
2012-03-05 11:43 ` Rajesh Borundia
2012-03-05 11:43   ` Rajesh Borundia
2012-03-05 20:35   ` David Miller
2012-03-05 20:35     ` David Miller
2012-03-07 19:41     ` Rajesh Borundia
2012-03-07 19:41       ` Rajesh Borundia
2012-03-09 15:13       ` santosh prasad nayak
2012-03-09 16:34 ` Rajesh Borundia
2012-03-09 16:34   ` Rajesh Borundia
2012-03-09 18:50   ` santosh prasad nayak
2012-03-09 18:51     ` santosh prasad nayak
2012-03-10 19:01     ` Rajesh Borundia
2012-03-10 19:01       ` Rajesh Borundia
2012-03-11  9:16       ` santosh prasad nayak
2012-03-11  9:28         ` santosh prasad nayak
2012-03-02 15:11         ` santosh nayak
2012-03-02 15:23           ` santosh nayak
2012-03-02 17:22           ` Rajesh Borundia
2012-03-02 17:22             ` Rajesh Borundia
2012-03-05 21:49           ` [PATCH 0001/001] xen: multi page ring support for block devices Santosh Jodh
2012-03-05 21:49           ` Santosh Jodh
2012-03-05 21:49           ` Santosh Jodh
2012-03-05 21:49             ` Santosh Jodh
2012-03-06  2:42             ` Rusty Russell
2012-03-06  2:42               ` Rusty Russell
2012-03-06  6:21               ` Santosh Jodh
2012-03-06  6:21               ` Santosh Jodh
2012-03-06  6:21                 ` Santosh Jodh
2012-03-06  6:21               ` Santosh Jodh
2012-03-06  2:42             ` Rusty Russell
2012-03-06  2:42             ` Rusty Russell
2012-03-06  8:34             ` Jan Beulich
2012-03-06  8:34             ` Jan Beulich
2012-03-06  8:34             ` Jan Beulich
2012-03-06  8:34               ` Jan Beulich
2012-03-14 17:17               ` Justin T. Gibbs
2012-03-14 17:17               ` [Xen-devel] " Justin T. Gibbs
2012-03-15  8:09                 ` Jan Beulich
2012-03-06 11:16             ` Wei Liu
2012-03-06 11:16             ` Wei Liu
2012-03-06 11:16               ` Wei Liu
2012-03-06 17:20             ` Konrad Rzeszutek Wilk
2012-03-06 17:20             ` [Xen-devel] " Konrad Rzeszutek Wilk
2012-03-07  9:33               ` Jan Beulich
2012-03-07  9:33                 ` Jan Beulich
2012-03-07  9:33                 ` Jan Beulich
2012-03-07 15:15                 ` Konrad Rzeszutek Wilk
2012-03-07 15:15                   ` Konrad Rzeszutek Wilk
2012-03-07 15:15                 ` Konrad Rzeszutek Wilk
2012-03-14  6:32                 ` Justin Gibbs
2012-03-14  6:32                 ` [Xen-devel] " Justin Gibbs
2012-03-14  6:32                   ` Justin Gibbs
2012-03-14  8:35                   ` Jan Beulich
2012-03-14  8:35                   ` [Xen-devel] " Jan Beulich
2012-03-14 15:34                   ` Jan Beulich
2012-03-14 17:01                     ` Justin Gibbs
2012-03-14 17:01                     ` [Xen-devel] " Justin Gibbs
2012-03-15  8:03                       ` Jan Beulich
2012-03-15  8:51                         ` Ian Campbell
2012-03-15  9:31                           ` Jan Beulich
2012-03-15  9:31                           ` Jan Beulich
2012-03-15  8:51                         ` Ian Campbell
2012-03-15  8:03                       ` Jan Beulich
2012-03-14 15:34                   ` Jan Beulich
2012-03-07  9:33               ` Jan Beulich
2012-03-12  9:37           ` [PATCH 3/3] netxen: qlogic ethernet : Fix Endian Bug David Laight
2012-03-12  9:37             ` David Laight
2012-03-12  9:47             ` santosh prasad nayak
2012-03-12  9:59               ` santosh prasad nayak
2012-03-12  6:19         ` Rajesh Borundia
2012-03-12  6:19           ` Rajesh Borundia

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.