]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
mt76: move mt76_mcu_msg_alloc in mt76-core
authorLorenzo Bianconi <lorenzo.bianconi@redhat.com>
Mon, 4 Feb 2019 16:51:27 +0000 (17:51 +0100)
committerFelix Fietkau <nbd@nbd.name>
Mon, 18 Feb 2019 18:54:33 +0000 (19:54 +0100)
Move mt76_mcu_msg_alloc in mt76-core module and remove duplicated code.
mt76_mcu_msg_alloc will be reused adding support for mt7603 driver

Signed-off-by: Lorenzo Bianconi <lorenzo.bianconi@redhat.com>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/Makefile
drivers/net/wireless/mediatek/mt76/mcu.c [new file with mode: 0644]
drivers/net/wireless/mediatek/mt76/mt76.h
drivers/net/wireless/mediatek/mt76/mt76x02_mcu.c
drivers/net/wireless/mediatek/mt76/mt76x02_mcu.h
drivers/net/wireless/mediatek/mt76/mt76x02_usb_mcu.c

index 1a45cb30f39f2ce7c856edc35302a93cda302d74..fa7a44edd02d6489ded5c5d4d0c9c3f6e1613f1f 100644 (file)
@@ -4,7 +4,8 @@ obj-$(CONFIG_MT76x02_LIB) += mt76x02-lib.o
 obj-$(CONFIG_MT76x02_USB) += mt76x02-usb.o
 
 mt76-y := \
-       mmio.o util.o trace.o dma.o mac80211.o debugfs.o eeprom.o tx.o agg-rx.o
+       mmio.o util.o trace.o dma.o mac80211.o debugfs.o eeprom.o \
+       tx.o agg-rx.o mcu.o
 
 mt76-usb-y := usb.o usb_trace.o usb_mcu.o
 
diff --git a/drivers/net/wireless/mediatek/mt76/mcu.c b/drivers/net/wireless/mediatek/mt76/mcu.c
new file mode 100644 (file)
index 0000000..f4c38ec
--- /dev/null
@@ -0,0 +1,36 @@
+/*
+ * Copyright (C) 2019 Lorenzo Bianconi <lorenzo.bianconi83@gmail.com>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include "mt76.h"
+
+struct sk_buff *
+mt76_mcu_msg_alloc(const void *data, int head_len,
+                  int data_len, int tail_len)
+{
+       struct sk_buff *skb;
+
+       skb = alloc_skb(head_len + data_len + tail_len,
+                       GFP_KERNEL);
+       if (!skb)
+               return NULL;
+
+       skb_reserve(skb, head_len);
+       if (data && data_len)
+               skb_put_data(skb, data, data_len);
+
+       return skb;
+}
+EXPORT_SYMBOL_GPL(mt76_mcu_msg_alloc);
index 2bb9db4ed80a9ab96068c9397ef2e77dd4fafa36..155d981d13280b044c202aadf8239317c7ff2079 100644 (file)
@@ -751,6 +751,10 @@ void mt76u_stop_queues(struct mt76_dev *dev);
 void mt76u_stop_stat_wk(struct mt76_dev *dev);
 void mt76u_queues_deinit(struct mt76_dev *dev);
 
+struct sk_buff *
+mt76_mcu_msg_alloc(const void *data, int head_len,
+                  int data_len, int tail_len);
+
 void mt76u_mcu_complete_urb(struct urb *urb);
 int mt76u_mcu_init_rx(struct mt76_dev *dev);
 void mt76u_mcu_deinit(struct mt76_dev *dev);
index b7f4edb729e38842362f2b4dac4d70abae232eb2..d184551b9845cbbe6b9cb99be03d6e81a809a3a4 100644 (file)
 
 #include "mt76x02_mcu.h"
 
-static struct sk_buff *mt76x02_mcu_msg_alloc(const void *data, int len)
-{
-       struct sk_buff *skb;
-
-       skb = alloc_skb(len, GFP_KERNEL);
-       if (!skb)
-               return NULL;
-       memcpy(skb_put(skb, len), data, len);
-
-       return skb;
-}
-
 static struct sk_buff *
 mt76x02_mcu_get_response(struct mt76x02_dev *dev, unsigned long expires)
 {
index 7e4004120102724a53d39d42095fdecba970cbf0..a7b0d3e5df1db6f9457b671956cb16e576735b1f 100644 (file)
@@ -96,6 +96,12 @@ struct mt76x02_patch_header {
        u8 pad[2];
 };
 
+static inline struct sk_buff *
+mt76x02_mcu_msg_alloc(const void *data, int len)
+{
+       return mt76_mcu_msg_alloc(data, 0, len, 0);
+}
+
 int mt76x02_mcu_cleanup(struct mt76x02_dev *dev);
 int mt76x02_mcu_calibrate(struct mt76x02_dev *dev, int type, u32 param);
 int mt76x02_mcu_msg_send(struct mt76_dev *mdev, int cmd, const void *data,
index 6db789f90269e855cd185e3376483cbddf89514f..ff070f8fbc614947bb6637352b825ba4d5198ce6 100644 (file)
 
 #define MT_TX_CPU_FROM_FCE_CPU_DESC_IDX        0x09a8
 
-static struct sk_buff *
-mt76x02u_mcu_msg_alloc(const void *data, int len)
-{
-       struct sk_buff *skb;
-
-       skb = alloc_skb(MT_CMD_HDR_LEN + len + 8, GFP_KERNEL);
-       if (!skb)
-               return NULL;
-
-       skb_reserve(skb, MT_CMD_HDR_LEN);
-       skb_put_data(skb, data, len);
-
-       return skb;
-}
-
 static void
 mt76x02u_multiple_mcu_reads(struct mt76_dev *dev, u8 *data, int len)
 {
@@ -166,7 +151,7 @@ mt76x02u_mcu_send_msg(struct mt76_dev *dev, int cmd, const void *data,
        struct sk_buff *skb;
        int err;
 
-       skb = mt76x02u_mcu_msg_alloc(data, len);
+       skb = mt76_mcu_msg_alloc(data, MT_CMD_HDR_LEN, len, 8);
        if (!skb)
                return -ENOMEM;