aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/ath9k/ahb.c
diff options
context:
space:
mode:
authorJouni Malinen <jouni.malinen@atheros.com>2009-03-03 12:23:28 -0500
committerJohn W. Linville <linville@tuxdriver.com>2009-03-05 14:39:44 -0500
commitbce048d77dff3dcfd75d54dc38580c81baa95853 (patch)
tree214b954bae87b52bad66c60f625c925be10b3500 /drivers/net/wireless/ath9k/ahb.c
parent8ca21f0185a606c490867f7471196aa29639e638 (diff)
ath9k: Add data structure for supporting virtual radio/wiphy operation
This is the initial step in allowing ath9k to register multiple virtual radios (wiphys). The goal of virtual radios is to allow the same radio to be shared for multiple virtual interfaces that may operate on different channels. The mac80211 virtual interface support is designed only for single channel operation and as such, it is not suitable for this type of use. Anyway, it can be used on top of the virtual radio concept, if desired (e.g., use two virtual radios to handle two channels and then add multiple mac80211 virtual interfaces on top of each virtual radio). The new struct ath_wiphy is now registered as the driver data structure for wiphy. This structure has a pointer to the shared (among virtual wiphys of the same physical radio) struct ath_softc data. The primary wiphy maintains the allocated memory for ath_softc. Secondary (virtual) wiphys will only allocate the new ath_wiphy structure. Registration of secondary wiphys is added in a separate patch. Signed-off-by: Jouni Malinen <jouni.malinen@atheros.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath9k/ahb.c')
-rw-r--r--drivers/net/wireless/ath9k/ahb.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/drivers/net/wireless/ath9k/ahb.c b/drivers/net/wireless/ath9k/ahb.c
index 391c9fd3b646..bc562bd88890 100644
--- a/drivers/net/wireless/ath9k/ahb.c
+++ b/drivers/net/wireless/ath9k/ahb.c
@@ -96,7 +96,8 @@ static int ath_ahb_probe(struct platform_device *pdev)
96 96
97 irq = res->start; 97 irq = res->start;
98 98
99 hw = ieee80211_alloc_hw(sizeof(struct ath_softc), &ath9k_ops); 99 hw = ieee80211_alloc_hw(sizeof(struct ath_wiphy) +
100 sizeof(struct ath_softc), &ath9k_ops);
100 if (hw == NULL) { 101 if (hw == NULL) {
101 dev_err(&pdev->dev, "no memory for ieee80211_hw\n"); 102 dev_err(&pdev->dev, "no memory for ieee80211_hw\n");
102 ret = -ENOMEM; 103 ret = -ENOMEM;
@@ -106,7 +107,11 @@ static int ath_ahb_probe(struct platform_device *pdev)
106 SET_IEEE80211_DEV(hw, &pdev->dev); 107 SET_IEEE80211_DEV(hw, &pdev->dev);
107 platform_set_drvdata(pdev, hw); 108 platform_set_drvdata(pdev, hw);
108 109
109 sc = hw->priv; 110 aphy = hw->priv;
111 sc = (struct ath_softc *) (aphy + 1);
112 aphy->sc = sc;
113 aphy->hw = hw;
114 sc->pri_wiphy = aphy;
110 sc->hw = hw; 115 sc->hw = hw;
111 sc->dev = &pdev->dev; 116 sc->dev = &pdev->dev;
112 sc->mem = mem; 117 sc->mem = mem;
@@ -156,7 +161,8 @@ static int ath_ahb_remove(struct platform_device *pdev)
156 struct ieee80211_hw *hw = platform_get_drvdata(pdev); 161 struct ieee80211_hw *hw = platform_get_drvdata(pdev);
157 162
158 if (hw) { 163 if (hw) {
159 struct ath_softc *sc = hw->priv; 164 struct ath_wiphy *aphy = hw->priv;
165 struct ath_softc *sc = aphy->sc;
160 166
161 ath_cleanup(sc); 167 ath_cleanup(sc);
162 platform_set_drvdata(pdev, NULL); 168 platform_set_drvdata(pdev, NULL);