diff options
-rw-r--r-- | drivers/net/cxgb3/common.h | 4 | ||||
-rw-r--r-- | drivers/net/cxgb3/cxgb3_main.c | 11 | ||||
-rw-r--r-- | drivers/net/cxgb3/sge.c | 4 | ||||
-rw-r--r-- | drivers/net/cxgb3/t3_hw.c | 31 |
4 files changed, 26 insertions, 24 deletions
diff --git a/drivers/net/cxgb3/common.h b/drivers/net/cxgb3/common.h index 99c75d30f67a..91ee7277b813 100644 --- a/drivers/net/cxgb3/common.h +++ b/drivers/net/cxgb3/common.h | |||
@@ -681,8 +681,8 @@ int t3_phy_intr_handler(struct adapter *adapter); | |||
681 | void t3_link_changed(struct adapter *adapter, int port_id); | 681 | void t3_link_changed(struct adapter *adapter, int port_id); |
682 | int t3_link_start(struct cphy *phy, struct cmac *mac, struct link_config *lc); | 682 | int t3_link_start(struct cphy *phy, struct cmac *mac, struct link_config *lc); |
683 | const struct adapter_info *t3_get_adapter_info(unsigned int board_id); | 683 | const struct adapter_info *t3_get_adapter_info(unsigned int board_id); |
684 | int t3_seeprom_read(struct adapter *adapter, u32 addr, u32 *data); | 684 | int t3_seeprom_read(struct adapter *adapter, u32 addr, __le32 *data); |
685 | int t3_seeprom_write(struct adapter *adapter, u32 addr, u32 data); | 685 | int t3_seeprom_write(struct adapter *adapter, u32 addr, __le32 data); |
686 | int t3_seeprom_wp(struct adapter *adapter, int enable); | 686 | int t3_seeprom_wp(struct adapter *adapter, int enable); |
687 | int t3_get_tp_version(struct adapter *adapter, u32 *vers); | 687 | int t3_get_tp_version(struct adapter *adapter, u32 *vers); |
688 | int t3_check_tpsram_version(struct adapter *adapter, int *must_load); | 688 | int t3_check_tpsram_version(struct adapter *adapter, int *must_load); |
diff --git a/drivers/net/cxgb3/cxgb3_main.c b/drivers/net/cxgb3/cxgb3_main.c index 0e3dcbff002d..fd2e05bbb903 100644 --- a/drivers/net/cxgb3/cxgb3_main.c +++ b/drivers/net/cxgb3/cxgb3_main.c | |||
@@ -1642,7 +1642,7 @@ static int get_eeprom(struct net_device *dev, struct ethtool_eeprom *e, | |||
1642 | 1642 | ||
1643 | e->magic = EEPROM_MAGIC; | 1643 | e->magic = EEPROM_MAGIC; |
1644 | for (i = e->offset & ~3; !err && i < e->offset + e->len; i += 4) | 1644 | for (i = e->offset & ~3; !err && i < e->offset + e->len; i += 4) |
1645 | err = t3_seeprom_read(adapter, i, (u32 *) & buf[i]); | 1645 | err = t3_seeprom_read(adapter, i, (__le32 *) & buf[i]); |
1646 | 1646 | ||
1647 | if (!err) | 1647 | if (!err) |
1648 | memcpy(data, buf + e->offset, e->len); | 1648 | memcpy(data, buf + e->offset, e->len); |
@@ -1655,7 +1655,8 @@ static int set_eeprom(struct net_device *dev, struct ethtool_eeprom *eeprom, | |||
1655 | { | 1655 | { |
1656 | struct port_info *pi = netdev_priv(dev); | 1656 | struct port_info *pi = netdev_priv(dev); |
1657 | struct adapter *adapter = pi->adapter; | 1657 | struct adapter *adapter = pi->adapter; |
1658 | u32 aligned_offset, aligned_len, *p; | 1658 | u32 aligned_offset, aligned_len; |
1659 | __le32 *p; | ||
1659 | u8 *buf; | 1660 | u8 *buf; |
1660 | int err; | 1661 | int err; |
1661 | 1662 | ||
@@ -1669,11 +1670,11 @@ static int set_eeprom(struct net_device *dev, struct ethtool_eeprom *eeprom, | |||
1669 | buf = kmalloc(aligned_len, GFP_KERNEL); | 1670 | buf = kmalloc(aligned_len, GFP_KERNEL); |
1670 | if (!buf) | 1671 | if (!buf) |
1671 | return -ENOMEM; | 1672 | return -ENOMEM; |
1672 | err = t3_seeprom_read(adapter, aligned_offset, (u32 *) buf); | 1673 | err = t3_seeprom_read(adapter, aligned_offset, (__le32 *) buf); |
1673 | if (!err && aligned_len > 4) | 1674 | if (!err && aligned_len > 4) |
1674 | err = t3_seeprom_read(adapter, | 1675 | err = t3_seeprom_read(adapter, |
1675 | aligned_offset + aligned_len - 4, | 1676 | aligned_offset + aligned_len - 4, |
1676 | (u32 *) & buf[aligned_len - 4]); | 1677 | (__le32 *) & buf[aligned_len - 4]); |
1677 | if (err) | 1678 | if (err) |
1678 | goto out; | 1679 | goto out; |
1679 | memcpy(buf + (eeprom->offset & 3), data, eeprom->len); | 1680 | memcpy(buf + (eeprom->offset & 3), data, eeprom->len); |
@@ -1684,7 +1685,7 @@ static int set_eeprom(struct net_device *dev, struct ethtool_eeprom *eeprom, | |||
1684 | if (err) | 1685 | if (err) |
1685 | goto out; | 1686 | goto out; |
1686 | 1687 | ||
1687 | for (p = (u32 *) buf; !err && aligned_len; aligned_len -= 4, p++) { | 1688 | for (p = (__le32 *) buf; !err && aligned_len; aligned_len -= 4, p++) { |
1688 | err = t3_seeprom_write(adapter, aligned_offset, *p); | 1689 | err = t3_seeprom_write(adapter, aligned_offset, *p); |
1689 | aligned_offset += 4; | 1690 | aligned_offset += 4; |
1690 | } | 1691 | } |
diff --git a/drivers/net/cxgb3/sge.c b/drivers/net/cxgb3/sge.c index 6367cee0d66a..cb684d30831f 100644 --- a/drivers/net/cxgb3/sge.c +++ b/drivers/net/cxgb3/sge.c | |||
@@ -1814,7 +1814,7 @@ static void rx_eth(struct adapter *adap, struct sge_rspq *rq, | |||
1814 | skb->protocol = eth_type_trans(skb, adap->port[p->iff]); | 1814 | skb->protocol = eth_type_trans(skb, adap->port[p->iff]); |
1815 | skb->dev->last_rx = jiffies; | 1815 | skb->dev->last_rx = jiffies; |
1816 | pi = netdev_priv(skb->dev); | 1816 | pi = netdev_priv(skb->dev); |
1817 | if (pi->rx_csum_offload && p->csum_valid && p->csum == 0xffff && | 1817 | if (pi->rx_csum_offload && p->csum_valid && p->csum == htons(0xffff) && |
1818 | !p->fragment) { | 1818 | !p->fragment) { |
1819 | rspq_to_qset(rq)->port_stats[SGE_PSTAT_RX_CSUM_GOOD]++; | 1819 | rspq_to_qset(rq)->port_stats[SGE_PSTAT_RX_CSUM_GOOD]++; |
1820 | skb->ip_summed = CHECKSUM_UNNECESSARY; | 1820 | skb->ip_summed = CHECKSUM_UNNECESSARY; |
@@ -1961,7 +1961,7 @@ static int process_responses(struct adapter *adap, struct sge_qset *qs, | |||
1961 | int eth, ethpad = 2; | 1961 | int eth, ethpad = 2; |
1962 | struct sk_buff *skb = NULL; | 1962 | struct sk_buff *skb = NULL; |
1963 | u32 len, flags = ntohl(r->flags); | 1963 | u32 len, flags = ntohl(r->flags); |
1964 | u32 rss_hi = *(const u32 *)r, rss_lo = r->rss_hdr.rss_hash_val; | 1964 | __be32 rss_hi = *(const __be32 *)r, rss_lo = r->rss_hdr.rss_hash_val; |
1965 | 1965 | ||
1966 | eth = r->rss_hdr.opcode == CPL_RX_PKT; | 1966 | eth = r->rss_hdr.opcode == CPL_RX_PKT; |
1967 | 1967 | ||
diff --git a/drivers/net/cxgb3/t3_hw.c b/drivers/net/cxgb3/t3_hw.c index 6e5b4992f17e..7469935877bd 100644 --- a/drivers/net/cxgb3/t3_hw.c +++ b/drivers/net/cxgb3/t3_hw.c | |||
@@ -537,10 +537,11 @@ struct t3_vpd { | |||
537 | * addres is written to the control register. The hardware device will | 537 | * addres is written to the control register. The hardware device will |
538 | * set the flag to 1 when 4 bytes have been read into the data register. | 538 | * set the flag to 1 when 4 bytes have been read into the data register. |
539 | */ | 539 | */ |
540 | int t3_seeprom_read(struct adapter *adapter, u32 addr, u32 *data) | 540 | int t3_seeprom_read(struct adapter *adapter, u32 addr, __le32 *data) |
541 | { | 541 | { |
542 | u16 val; | 542 | u16 val; |
543 | int attempts = EEPROM_MAX_POLL; | 543 | int attempts = EEPROM_MAX_POLL; |
544 | u32 v; | ||
544 | unsigned int base = adapter->params.pci.vpd_cap_addr; | 545 | unsigned int base = adapter->params.pci.vpd_cap_addr; |
545 | 546 | ||
546 | if ((addr >= EEPROMSIZE && addr != EEPROM_STAT_ADDR) || (addr & 3)) | 547 | if ((addr >= EEPROMSIZE && addr != EEPROM_STAT_ADDR) || (addr & 3)) |
@@ -556,8 +557,8 @@ int t3_seeprom_read(struct adapter *adapter, u32 addr, u32 *data) | |||
556 | CH_ERR(adapter, "reading EEPROM address 0x%x failed\n", addr); | 557 | CH_ERR(adapter, "reading EEPROM address 0x%x failed\n", addr); |
557 | return -EIO; | 558 | return -EIO; |
558 | } | 559 | } |
559 | pci_read_config_dword(adapter->pdev, base + PCI_VPD_DATA, data); | 560 | pci_read_config_dword(adapter->pdev, base + PCI_VPD_DATA, &v); |
560 | *data = le32_to_cpu(*data); | 561 | *data = cpu_to_le32(v); |
561 | return 0; | 562 | return 0; |
562 | } | 563 | } |
563 | 564 | ||
@@ -570,7 +571,7 @@ int t3_seeprom_read(struct adapter *adapter, u32 addr, u32 *data) | |||
570 | * Write a 32-bit word to a location in VPD EEPROM using the card's PCI | 571 | * Write a 32-bit word to a location in VPD EEPROM using the card's PCI |
571 | * VPD ROM capability. | 572 | * VPD ROM capability. |
572 | */ | 573 | */ |
573 | int t3_seeprom_write(struct adapter *adapter, u32 addr, u32 data) | 574 | int t3_seeprom_write(struct adapter *adapter, u32 addr, __le32 data) |
574 | { | 575 | { |
575 | u16 val; | 576 | u16 val; |
576 | int attempts = EEPROM_MAX_POLL; | 577 | int attempts = EEPROM_MAX_POLL; |
@@ -580,7 +581,7 @@ int t3_seeprom_write(struct adapter *adapter, u32 addr, u32 data) | |||
580 | return -EINVAL; | 581 | return -EINVAL; |
581 | 582 | ||
582 | pci_write_config_dword(adapter->pdev, base + PCI_VPD_DATA, | 583 | pci_write_config_dword(adapter->pdev, base + PCI_VPD_DATA, |
583 | cpu_to_le32(data)); | 584 | le32_to_cpu(data)); |
584 | pci_write_config_word(adapter->pdev,base + PCI_VPD_ADDR, | 585 | pci_write_config_word(adapter->pdev,base + PCI_VPD_ADDR, |
585 | addr | PCI_VPD_ADDR_F); | 586 | addr | PCI_VPD_ADDR_F); |
586 | do { | 587 | do { |
@@ -631,14 +632,14 @@ static int get_vpd_params(struct adapter *adapter, struct vpd_params *p) | |||
631 | * Card information is normally at VPD_BASE but some early cards had | 632 | * Card information is normally at VPD_BASE but some early cards had |
632 | * it at 0. | 633 | * it at 0. |
633 | */ | 634 | */ |
634 | ret = t3_seeprom_read(adapter, VPD_BASE, (u32 *)&vpd); | 635 | ret = t3_seeprom_read(adapter, VPD_BASE, (__le32 *)&vpd); |
635 | if (ret) | 636 | if (ret) |
636 | return ret; | 637 | return ret; |
637 | addr = vpd.id_tag == 0x82 ? VPD_BASE : 0; | 638 | addr = vpd.id_tag == 0x82 ? VPD_BASE : 0; |
638 | 639 | ||
639 | for (i = 0; i < sizeof(vpd); i += 4) { | 640 | for (i = 0; i < sizeof(vpd); i += 4) { |
640 | ret = t3_seeprom_read(adapter, addr + i, | 641 | ret = t3_seeprom_read(adapter, addr + i, |
641 | (u32 *)((u8 *)&vpd + i)); | 642 | (__le32 *)((u8 *)&vpd + i)); |
642 | if (ret) | 643 | if (ret) |
643 | return ret; | 644 | return ret; |
644 | } | 645 | } |
@@ -926,7 +927,7 @@ int t3_check_tpsram(struct adapter *adapter, u8 *tp_sram, unsigned int size) | |||
926 | { | 927 | { |
927 | u32 csum; | 928 | u32 csum; |
928 | unsigned int i; | 929 | unsigned int i; |
929 | const u32 *p = (const u32 *)tp_sram; | 930 | const __be32 *p = (const __be32 *)tp_sram; |
930 | 931 | ||
931 | /* Verify checksum */ | 932 | /* Verify checksum */ |
932 | for (csum = 0, i = 0; i < size / sizeof(csum); i++) | 933 | for (csum = 0, i = 0; i < size / sizeof(csum); i++) |
@@ -1040,7 +1041,7 @@ int t3_load_fw(struct adapter *adapter, const u8 *fw_data, unsigned int size) | |||
1040 | { | 1041 | { |
1041 | u32 csum; | 1042 | u32 csum; |
1042 | unsigned int i; | 1043 | unsigned int i; |
1043 | const u32 *p = (const u32 *)fw_data; | 1044 | const __be32 *p = (const __be32 *)fw_data; |
1044 | int ret, addr, fw_sector = FW_FLASH_BOOT_ADDR >> 16; | 1045 | int ret, addr, fw_sector = FW_FLASH_BOOT_ADDR >> 16; |
1045 | 1046 | ||
1046 | if ((size & 3) || size < FW_MIN_SIZE) | 1047 | if ((size & 3) || size < FW_MIN_SIZE) |
@@ -2877,14 +2878,14 @@ static void ulp_config(struct adapter *adap, const struct tp_params *p) | |||
2877 | int t3_set_proto_sram(struct adapter *adap, u8 *data) | 2878 | int t3_set_proto_sram(struct adapter *adap, u8 *data) |
2878 | { | 2879 | { |
2879 | int i; | 2880 | int i; |
2880 | u32 *buf = (u32 *)data; | 2881 | __be32 *buf = (__be32 *)data; |
2881 | 2882 | ||
2882 | for (i = 0; i < PROTO_SRAM_LINES; i++) { | 2883 | for (i = 0; i < PROTO_SRAM_LINES; i++) { |
2883 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD5, cpu_to_be32(*buf++)); | 2884 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD5, be32_to_cpu(*buf++)); |
2884 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD4, cpu_to_be32(*buf++)); | 2885 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD4, be32_to_cpu(*buf++)); |
2885 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD3, cpu_to_be32(*buf++)); | 2886 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD3, be32_to_cpu(*buf++)); |
2886 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD2, cpu_to_be32(*buf++)); | 2887 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD2, be32_to_cpu(*buf++)); |
2887 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD1, cpu_to_be32(*buf++)); | 2888 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD1, be32_to_cpu(*buf++)); |
2888 | 2889 | ||
2889 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD0, i << 1 | 1 << 31); | 2890 | t3_write_reg(adap, A_TP_EMBED_OP_FIELD0, i << 1 | 1 << 31); |
2890 | if (t3_wait_op_done(adap, A_TP_EMBED_OP_FIELD0, 1, 1, 5, 1)) | 2891 | if (t3_wait_op_done(adap, A_TP_EMBED_OP_FIELD0, 1, 1, 5, 1)) |