aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/wireless/brcm80211/brcmsmac/srom.c33
1 files changed, 15 insertions, 18 deletions
diff --git a/drivers/net/wireless/brcm80211/brcmsmac/srom.c b/drivers/net/wireless/brcm80211/brcmsmac/srom.c
index 8f1cf2f733e5..0539a6a831c5 100644
--- a/drivers/net/wireless/brcm80211/brcmsmac/srom.c
+++ b/drivers/net/wireless/brcm80211/brcmsmac/srom.c
@@ -617,18 +617,16 @@ static uint mask_width(u16 mask)
617 return 0; 617 return 0;
618} 618}
619 619
620static inline void le16_to_cpu_buf(u16 *buf, unsigned int size) 620static inline void le16_to_cpu_buf(u16 *buf, uint nwords)
621{ 621{
622 size /= 2; 622 while (nwords--)
623 while (size--) 623 *(buf + nwords) = le16_to_cpu(*(__le16 *)(buf + nwords));
624 *(buf + size) = le16_to_cpu(*(__le16 *)(buf + size));
625} 624}
626 625
627static inline void cpu_to_le16_buf(u16 *buf, unsigned int size) 626static inline void cpu_to_le16_buf(u16 *buf, uint nwords)
628{ 627{
629 size /= 2; 628 while (nwords--)
630 while (size--) 629 *(__le16 *)(buf + nwords) = cpu_to_le16(*(buf + nwords));
631 *(__le16 *)(buf + size) = cpu_to_le16(*(buf + size));
632} 630}
633 631
634/* 632/*
@@ -807,12 +805,12 @@ sprom_read_pci(struct si_pub *sih, u8 __iomem *sprom, uint wordoff,
807 err = -EIO; 805 err = -EIO;
808 else 806 else
809 /* now correct the endianness of the byte array */ 807 /* now correct the endianness of the byte array */
810 le16_to_cpu_buf(buf, nbytes); 808 le16_to_cpu_buf(buf, nwords);
811 809
812 return err; 810 return err;
813} 811}
814 812
815static int otp_read_pci(struct si_pub *sih, u16 *buf, uint bufsz) 813static int otp_read_pci(struct si_pub *sih, u16 *buf, uint nwords)
816{ 814{
817 u8 *otp; 815 u8 *otp;
818 uint sz = OTP_SZ_MAX / 2; /* size in words */ 816 uint sz = OTP_SZ_MAX / 2; /* size in words */
@@ -824,7 +822,8 @@ static int otp_read_pci(struct si_pub *sih, u16 *buf, uint bufsz)
824 822
825 err = otp_read_region(sih, OTP_HW_RGN, (u16 *) otp, &sz); 823 err = otp_read_region(sih, OTP_HW_RGN, (u16 *) otp, &sz);
826 824
827 memcpy(buf, otp, bufsz); 825 sz = min_t(uint, sz, nwords);
826 memcpy(buf, otp, sz * 2);
828 827
829 kfree(otp); 828 kfree(otp);
830 829
@@ -836,14 +835,12 @@ static int otp_read_pci(struct si_pub *sih, u16 *buf, uint bufsz)
836 */ 835 */
837 return -ENODATA; 836 return -ENODATA;
838 837
839 /* fixup the endianness so crc8 will pass */ 838 if (crc8(brcms_srom_crc8_table, (u8 *) buf, sz * 2,
840 cpu_to_le16_buf(buf, bufsz);
841 if (crc8(brcms_srom_crc8_table, (u8 *) buf, SROM4_WORDS * 2,
842 CRC8_INIT_VALUE) != CRC8_GOOD_VALUE(brcms_srom_crc8_table)) 839 CRC8_INIT_VALUE) != CRC8_GOOD_VALUE(brcms_srom_crc8_table))
843 err = -EIO; 840 err = -EIO;
844 841 else
845 /* now correct the endianness of the byte array */ 842 /* now correct the endianness of the byte array */
846 le16_to_cpu_buf(buf, bufsz); 843 le16_to_cpu_buf(buf, sz);
847 844
848 return err; 845 return err;
849} 846}
@@ -880,7 +877,7 @@ static int initvars_srom_pci(struct si_pub *sih, void __iomem *curmap)
880 sromrev = srom[SROM4_CRCREV] & 0xff; 877 sromrev = srom[SROM4_CRCREV] & 0xff;
881 } else { 878 } else {
882 /* Use OTP if SPROM not available */ 879 /* Use OTP if SPROM not available */
883 err = otp_read_pci(sih, srom, SROM_MAX); 880 err = otp_read_pci(sih, srom, SROM4_WORDS);
884 if (err == 0) 881 if (err == 0)
885 /* OTP only contain SROM rev8/rev9 for now */ 882 /* OTP only contain SROM rev8/rev9 for now */
886 sromrev = srom[SROM4_CRCREV] & 0xff; 883 sromrev = srom[SROM4_CRCREV] & 0xff;