diff options
author | Alexander Aring <alex.aring@gmail.com> | 2014-07-02 18:20:46 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-07-08 00:29:24 -0400 |
commit | a53d1f7c3d53353f68b2355a19cd5d5c7e4c7b34 (patch) | |
tree | d5899ef6972c2a773e27c6c159eb1fa4b72a6185 /drivers/net/ieee802154 | |
parent | c8ee0f56c833d70a03f06bf809089423dd190ee8 (diff) |
at86rf230: remove is212 and add driver data
This patch adds a new at86rf2xx_chip_data structure which holds device
specific attributes. Instead of runtime decisions "if (is212())" we set
callbacks/attributes while device detection.
Signed-off-by: Alexander Aring <alex.aring@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ieee802154')
-rw-r--r-- | drivers/net/ieee802154/at86rf230.c | 59 |
1 files changed, 36 insertions, 23 deletions
diff --git a/drivers/net/ieee802154/at86rf230.c b/drivers/net/ieee802154/at86rf230.c index 7d96cd410edb..694f5cf339e3 100644 --- a/drivers/net/ieee802154/at86rf230.c +++ b/drivers/net/ieee802154/at86rf230.c | |||
@@ -38,12 +38,19 @@ | |||
38 | #include <net/mac802154.h> | 38 | #include <net/mac802154.h> |
39 | #include <net/wpan-phy.h> | 39 | #include <net/wpan-phy.h> |
40 | 40 | ||
41 | struct at86rf230_local; | ||
42 | /* at86rf2xx chip depend data. | ||
43 | * All timings are in us. | ||
44 | */ | ||
45 | struct at86rf2xx_chip_data { | ||
46 | int rssi_base_val; | ||
47 | |||
48 | int (*set_channel)(struct at86rf230_local *, int, int); | ||
49 | }; | ||
50 | |||
41 | struct at86rf230_local { | 51 | struct at86rf230_local { |
42 | struct spi_device *spi; | 52 | struct spi_device *spi; |
43 | 53 | ||
44 | u8 part; | ||
45 | u8 vers; | ||
46 | |||
47 | u8 buf[2]; | 54 | u8 buf[2]; |
48 | struct mutex bmux; | 55 | struct mutex bmux; |
49 | 56 | ||
@@ -56,16 +63,11 @@ struct at86rf230_local { | |||
56 | spinlock_t lock; | 63 | spinlock_t lock; |
57 | bool irq_busy; | 64 | bool irq_busy; |
58 | bool is_tx; | 65 | bool is_tx; |
59 | bool tx_aret; | ||
60 | 66 | ||
61 | int rssi_base_val; | 67 | struct at86rf2xx_chip_data *data; |
68 | bool tx_aret; | ||
62 | }; | 69 | }; |
63 | 70 | ||
64 | static bool is_rf212(struct at86rf230_local *local) | ||
65 | { | ||
66 | return local->part == 7; | ||
67 | } | ||
68 | |||
69 | #define RG_TRX_STATUS (0x01) | 71 | #define RG_TRX_STATUS (0x01) |
70 | #define SR_TRX_STATUS 0x01, 0x1f, 0 | 72 | #define SR_TRX_STATUS 0x01, 0x1f, 0 |
71 | #define SR_RESERVED_01_3 0x01, 0x20, 5 | 73 | #define SR_RESERVED_01_3 0x01, 0x20, 5 |
@@ -593,10 +595,8 @@ at86rf230_stop(struct ieee802154_dev *dev) | |||
593 | } | 595 | } |
594 | 596 | ||
595 | static int | 597 | static int |
596 | at86rf230_set_channel(struct at86rf230_local *lp, int page, int channel) | 598 | at86rf23x_set_channel(struct at86rf230_local *lp, int page, int channel) |
597 | { | 599 | { |
598 | lp->rssi_base_val = -91; | ||
599 | |||
600 | return at86rf230_write_subreg(lp, SR_CHANNEL, channel); | 600 | return at86rf230_write_subreg(lp, SR_CHANNEL, channel); |
601 | } | 601 | } |
602 | 602 | ||
@@ -614,10 +614,10 @@ at86rf212_set_channel(struct at86rf230_local *lp, int page, int channel) | |||
614 | 614 | ||
615 | if (page == 0) { | 615 | if (page == 0) { |
616 | rc = at86rf230_write_subreg(lp, SR_BPSK_QPSK, 0); | 616 | rc = at86rf230_write_subreg(lp, SR_BPSK_QPSK, 0); |
617 | lp->rssi_base_val = -100; | 617 | lp->data->rssi_base_val = -100; |
618 | } else { | 618 | } else { |
619 | rc = at86rf230_write_subreg(lp, SR_BPSK_QPSK, 1); | 619 | rc = at86rf230_write_subreg(lp, SR_BPSK_QPSK, 1); |
620 | lp->rssi_base_val = -98; | 620 | lp->data->rssi_base_val = -98; |
621 | } | 621 | } |
622 | if (rc < 0) | 622 | if (rc < 0) |
623 | return rc; | 623 | return rc; |
@@ -639,10 +639,7 @@ at86rf230_channel(struct ieee802154_dev *dev, int page, int channel) | |||
639 | return -EINVAL; | 639 | return -EINVAL; |
640 | } | 640 | } |
641 | 641 | ||
642 | if (is_rf212(lp)) | 642 | rc = lp->data->set_channel(lp, page, channel); |
643 | rc = at86rf212_set_channel(lp, page, channel); | ||
644 | else | ||
645 | rc = at86rf230_set_channel(lp, page, channel); | ||
646 | if (rc < 0) | 643 | if (rc < 0) |
647 | return rc; | 644 | return rc; |
648 | 645 | ||
@@ -827,10 +824,10 @@ at86rf230_set_cca_ed_level(struct ieee802154_dev *dev, s32 level) | |||
827 | struct at86rf230_local *lp = dev->priv; | 824 | struct at86rf230_local *lp = dev->priv; |
828 | int desens_steps; | 825 | int desens_steps; |
829 | 826 | ||
830 | if (level < lp->rssi_base_val || level > 30) | 827 | if (level < lp->data->rssi_base_val || level > 30) |
831 | return -EINVAL; | 828 | return -EINVAL; |
832 | 829 | ||
833 | desens_steps = (level - lp->rssi_base_val) * 100 / 207; | 830 | desens_steps = (level - lp->data->rssi_base_val) * 100 / 207; |
834 | 831 | ||
835 | return at86rf230_write_subreg(lp, SR_CCA_ED_THRES, desens_steps); | 832 | return at86rf230_write_subreg(lp, SR_CCA_ED_THRES, desens_steps); |
836 | } | 833 | } |
@@ -889,6 +886,21 @@ static struct ieee802154_ops at86rf230_ops = { | |||
889 | .set_frame_retries = at86rf230_set_frame_retries, | 886 | .set_frame_retries = at86rf230_set_frame_retries, |
890 | }; | 887 | }; |
891 | 888 | ||
889 | static struct at86rf2xx_chip_data at86rf233_data = { | ||
890 | .rssi_base_val = -91, | ||
891 | .set_channel = at86rf23x_set_channel, | ||
892 | }; | ||
893 | |||
894 | static struct at86rf2xx_chip_data at86rf231_data = { | ||
895 | .rssi_base_val = -91, | ||
896 | .set_channel = at86rf23x_set_channel, | ||
897 | }; | ||
898 | |||
899 | static struct at86rf2xx_chip_data at86rf212_data = { | ||
900 | .rssi_base_val = -100, | ||
901 | .set_channel = at86rf212_set_channel, | ||
902 | }; | ||
903 | |||
892 | static void at86rf230_irqwork(struct work_struct *work) | 904 | static void at86rf230_irqwork(struct work_struct *work) |
893 | { | 905 | { |
894 | struct at86rf230_local *lp = | 906 | struct at86rf230_local *lp = |
@@ -1061,8 +1073,6 @@ at86rf230_detect_device(struct at86rf230_local *lp) | |||
1061 | return -EINVAL; | 1073 | return -EINVAL; |
1062 | } | 1074 | } |
1063 | 1075 | ||
1064 | lp->part = part; | ||
1065 | lp->vers = version; | ||
1066 | lp->dev->extra_tx_headroom = 0; | 1076 | lp->dev->extra_tx_headroom = 0; |
1067 | lp->dev->flags = IEEE802154_HW_OMIT_CKSUM | IEEE802154_HW_AACK | | 1077 | lp->dev->flags = IEEE802154_HW_OMIT_CKSUM | IEEE802154_HW_AACK | |
1068 | IEEE802154_HW_TXPOWER | IEEE802154_HW_CSMA; | 1078 | IEEE802154_HW_TXPOWER | IEEE802154_HW_CSMA; |
@@ -1074,11 +1084,13 @@ at86rf230_detect_device(struct at86rf230_local *lp) | |||
1074 | break; | 1084 | break; |
1075 | case 3: | 1085 | case 3: |
1076 | chip = "at86rf231"; | 1086 | chip = "at86rf231"; |
1087 | lp->data = &at86rf231_data; | ||
1077 | lp->dev->phy->channels_supported[0] = 0x7FFF800; | 1088 | lp->dev->phy->channels_supported[0] = 0x7FFF800; |
1078 | break; | 1089 | break; |
1079 | case 7: | 1090 | case 7: |
1080 | chip = "at86rf212"; | 1091 | chip = "at86rf212"; |
1081 | if (version == 1) { | 1092 | if (version == 1) { |
1093 | lp->data = &at86rf212_data; | ||
1082 | lp->dev->flags |= IEEE802154_HW_LBT; | 1094 | lp->dev->flags |= IEEE802154_HW_LBT; |
1083 | lp->dev->phy->channels_supported[0] = 0x00007FF; | 1095 | lp->dev->phy->channels_supported[0] = 0x00007FF; |
1084 | lp->dev->phy->channels_supported[2] = 0x00007FF; | 1096 | lp->dev->phy->channels_supported[2] = 0x00007FF; |
@@ -1088,6 +1100,7 @@ at86rf230_detect_device(struct at86rf230_local *lp) | |||
1088 | break; | 1100 | break; |
1089 | case 11: | 1101 | case 11: |
1090 | chip = "at86rf233"; | 1102 | chip = "at86rf233"; |
1103 | lp->data = &at86rf233_data; | ||
1091 | lp->dev->phy->channels_supported[0] = 0x7FFF800; | 1104 | lp->dev->phy->channels_supported[0] = 0x7FFF800; |
1092 | break; | 1105 | break; |
1093 | default: | 1106 | default: |