devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Kalle Valo <kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
To: linux-wireless-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Cc: ath11k-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org,
	devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: [PATCH 07/49] ath11k: add ce.h
Date: Tue, 20 Aug 2019 18:47:33 +0300	[thread overview]
Message-ID: <1566316095-27507-8-git-send-email-kvalo@codeaurora.org> (raw)
In-Reply-To: <1566316095-27507-1-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>

---
 drivers/net/wireless/ath/ath11k/ce.h | 178 +++++++++++++++++++++++++++++++++++
 1 file changed, 178 insertions(+)

diff --git a/drivers/net/wireless/ath/ath11k/ce.h b/drivers/net/wireless/ath/ath11k/ce.h
new file mode 100644
index 000000000000..b9f8a0b4cd7e
--- /dev/null
+++ b/drivers/net/wireless/ath/ath11k/ce.h
@@ -0,0 +1,178 @@
+/* SPDX-License-Identifier: ISC */
+/*
+ * Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.
+ */
+
+#ifndef ATH11K_CE_H
+#define ATH11K_CE_H
+
+#define CE_COUNT 12
+
+/* Byte swap data words */
+#define CE_ATTR_BYTE_SWAP_DATA 2
+
+/* no interrupt on copy completion */
+#define CE_ATTR_DIS_INTR		8
+
+/* Host software's Copy Engine configuration. */
+#ifdef __BIG_ENDIAN
+#define CE_ATTR_FLAGS CE_ATTR_BYTE_SWAP_DATA
+#else
+#define CE_ATTR_FLAGS 0
+#endif
+
+/* Threshold to poll for tx completion in case of Interrupt disabled CE's */
+#define ATH11K_CE_USAGE_THRESHOLD 32
+
+void ath11k_ce_byte_swap(void *mem, u32 len);
+
+/*
+ * Directions for interconnect pipe configuration.
+ * These definitions may be used during configuration and are shared
+ * between Host and Target.
+ *
+ * Pipe Directions are relative to the Host, so PIPEDIR_IN means
+ * "coming IN over air through Target to Host" as with a WiFi Rx operation.
+ * Conversely, PIPEDIR_OUT means "going OUT from Host through Target over air"
+ * as with a WiFi Tx operation. This is somewhat awkward for the "middle-man"
+ * Target since things that are "PIPEDIR_OUT" are coming IN to the Target
+ * over the interconnect.
+ */
+#define PIPEDIR_NONE		0
+#define PIPEDIR_IN		1 /* Target-->Host, WiFi Rx direction */
+#define PIPEDIR_OUT		2 /* Host->Target, WiFi Tx direction */
+#define PIPEDIR_INOUT		3 /* bidirectional */
+#define PIPEDIR_INOUT_H2H	4 /* bidirectional, host to host */
+
+/* CE address/mask */
+#define CE_HOST_IE_ADDRESS	0x00A1803C
+#define CE_HOST_IE_2_ADDRESS	0x00A18040
+#define CE_HOST_IE_3_ADDRESS	CE_HOST_IE_ADDRESS
+
+#define CE_HOST_IE_3_SHIFT	0xC
+
+#define CE_RING_IDX_INCR(nentries_mask, idx) (((idx) + 1) & (nentries_mask))
+
+#define ATH11K_CE_RX_POST_RETRY_JIFFIES 50
+
+struct ath11k_base;
+
+/* Establish a mapping between a service/direction and a pipe. */
+struct service_to_pipe {
+	__le32 service_id;
+	__le32 pipedir;
+	__le32 pipenum;
+};
+
+/*
+ * Configuration information for a Copy Engine pipe.
+ * Passed from Host to Target during startup (one per CE).
+ *
+ * NOTE: Structure is shared between Host software and Target firmware!
+ */
+struct ce_pipe_config {
+	__le32 pipenum;
+	__le32 pipedir;
+	__le32 nentries;
+	__le32 nbytes_max;
+	__le32 flags;
+	__le32 reserved;
+};
+
+struct ce_attr {
+	/* CE_ATTR_* values */
+	unsigned int flags;
+
+	/* #entries in source ring - Must be a power of 2 */
+	unsigned int src_nentries;
+
+	/*
+	 * Max source send size for this CE.
+	 * This is also the minimum size of a destination buffer.
+	 */
+	unsigned int src_sz_max;
+
+	/* #entries in destination ring - Must be a power of 2 */
+	unsigned int dest_nentries;
+
+	void (*recv_cb)(struct ath11k_base *, struct sk_buff *);
+};
+
+#define CE_DESC_RING_ALIGN 8
+
+struct ath11k_ce_ring {
+	/* Number of entries in this ring; must be power of 2 */
+	unsigned int nentries;
+	unsigned int nentries_mask;
+
+	/* For dest ring, this is the next index to be processed
+	 * by software after it was/is received into.
+	 *
+	 * For src ring, this is the last descriptor that was sent
+	 * and completion processed by software.
+	 *
+	 * Regardless of src or dest ring, this is an invariant
+	 * (modulo ring size):
+	 *     write index >= read index >= sw_index
+	 */
+	unsigned int sw_index;
+	/* cached copy */
+	unsigned int write_index;
+
+	/* Start of DMA-coherent area reserved for descriptors */
+	/* Host address space */
+	void *base_addr_owner_space_unaligned;
+	/* CE address space */
+	u32 base_addr_ce_space_unaligned;
+
+	/* Actual start of descriptors.
+	 * Aligned to descriptor-size boundary.
+	 * Points into reserved DMA-coherent area, above.
+	 */
+	/* Host address space */
+	void *base_addr_owner_space;
+
+	/* CE address space */
+	u32 base_addr_ce_space;
+
+	/* HAL ring id */
+	u32 hal_ring_id;
+
+	/* keep last */
+	struct sk_buff *skb[0];
+};
+
+struct ath11k_ce_pipe {
+	struct ath11k_base *ab;
+	u16 pipe_num;
+	unsigned int attr_flags;
+	unsigned int buf_sz;
+	unsigned int rx_buf_needed;
+
+	void (*send_cb)(struct ath11k_ce_pipe *);
+	void (*recv_cb)(struct ath11k_base *, struct sk_buff *);
+
+	struct tasklet_struct intr_tq;
+	struct ath11k_ce_ring *src_ring;
+	struct ath11k_ce_ring *dest_ring;
+	struct ath11k_ce_ring *status_ring;
+};
+
+struct ath11k_ce {
+	struct ath11k_ce_pipe ce_pipe[CE_COUNT];
+	/* Protects rings of all ce pipes */
+	spinlock_t ce_lock;
+};
+
+void ath11k_ce_cleanup_pipes(struct ath11k_base *ab);
+void ath11k_ce_rx_replenish_retry(struct timer_list *t);
+void ath11k_ce_per_engine_service(struct ath11k_base *ab, u16 ce_id);
+int ath11k_ce_send(struct ath11k_base *ab, struct sk_buff *skb, u8 pipe_id,
+		   u16 transfer_id);
+void ath11k_ce_rx_post_buf(struct ath11k_base *ab);
+int ath11k_ce_init_pipes(struct ath11k_base *ab);
+int ath11k_ce_alloc_pipes(struct ath11k_base *ab);
+void ath11k_ce_free_pipes(struct ath11k_base *ab);
+int ath11k_ce_get_attr_flags(int ce_id);
+void ath11k_ce_poll_send_completed(struct ath11k_base *ab, u8 pipe_id);
+#endif

  parent reply	other threads:[~2019-08-20 15:47 UTC|newest]

Thread overview: 85+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-08-20 15:47 [PATCH 00/49] ath11k: driver for Qualcomm IEEE 802.11ax devices Kalle Valo
     [not found] ` <1566316095-27507-1-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-20 15:47   ` [PATCH 01/49] dt: bindings: net: add qcom,ath11k.txt Kalle Valo
     [not found]     ` <1566316095-27507-2-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-27 17:13       ` Rob Herring
2019-09-05 13:18         ` Kalle Valo
2019-08-20 15:47   ` [PATCH 02/49] ath11k: add Kconfig Kalle Valo
     [not found]     ` <1566316095-27507-3-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-20 16:52       ` John Crispin
2019-08-20 15:47   ` [PATCH 03/49] ath11k: add Makefile Kalle Valo
2019-08-20 15:47   ` [PATCH 04/49] ath11k: add ahb.c Kalle Valo
     [not found]     ` <1566316095-27507-5-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-20 20:05       ` Johannes Berg
     [not found]         ` <8c791df54a831f32fddd634e71e5e91342532535.camel-cdvu00un1VgdHxzADdlk8Q@public.gmane.org>
2019-08-21  9:29           ` Vasanthakumar Thiagarajan
     [not found]             ` <e53ddcaa11d069fbe9d083b9b0105d19-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-21  9:40               ` Johannes Berg
     [not found]                 ` <e0cbf7b86b275f87c0a69bd9a31e5b9fa8691d3a.camel-cdvu00un1VgdHxzADdlk8Q@public.gmane.org>
2019-08-21 17:10                   ` Vasanthakumar Thiagarajan
2019-08-20 15:47   ` [PATCH 05/49] ath11k: add ahb.h Kalle Valo
2019-08-20 15:47   ` [PATCH 06/49] ath11k: add ce.c Kalle Valo
     [not found]     ` <1566316095-27507-7-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-20 20:23       ` Johannes Berg
     [not found]         ` <54d8d4600d53bac855b19a26fa744ed16be09bf0.camel-cdvu00un1VgdHxzADdlk8Q@public.gmane.org>
2019-08-21  9:45           ` Vasanthakumar Thiagarajan
2019-08-20 15:47   ` Kalle Valo [this message]
2019-08-20 15:47   ` [PATCH 08/49] ath11k: add core.c Kalle Valo
     [not found]     ` <1566316095-27507-9-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-20 20:32       ` Johannes Berg
     [not found]         ` <0c526ce00e6e1c7731c990515e7438230efb55af.camel-cdvu00un1VgdHxzADdlk8Q@public.gmane.org>
2019-09-05 11:37           ` Kalle Valo
2019-08-20 15:47   ` [PATCH 09/49] ath11k: add core.h Kalle Valo
2019-08-20 15:47   ` [PATCH 10/49] ath11k: add debug.c Kalle Valo
     [not found]     ` <1566316095-27507-11-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-26 13:47       ` Sven Eckelmann
2019-08-27  7:33         ` Anilkumar Kolli
     [not found]           ` <80bdedf3740960e0ce05b02a77d1b457-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-27  7:35             ` Sven Eckelmann
2019-08-27  9:04               ` Anilkumar Kolli
     [not found]                 ` <6622b83f754404ec05b9442027757c5e-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-27  9:53                   ` Sven Eckelmann
2019-08-27 10:04                     ` Anilkumar Kolli
     [not found]                       ` <f93b9c98fcfb9a910c3efc04d11d5aa0-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-27 10:49                         ` Sven Eckelmann
2019-08-20 15:47   ` [PATCH 11/49] ath11k: add debug.h Kalle Valo
2019-08-20 15:47   ` [PATCH 12/49] ath11k: add debug_htt_stats.c Kalle Valo
2019-08-20 15:47   ` [PATCH 13/49] ath11k: add debug_htt_stats.h Kalle Valo
2019-08-20 15:47   ` [PATCH 14/49] ath11k: add debugfs_sta.c Kalle Valo
2019-08-20 15:47   ` [PATCH 15/49] ath11k: add dp.c Kalle Valo
2019-08-20 15:47   ` [PATCH 16/49] ath11k: add dp.h Kalle Valo
2019-08-20 15:47   ` [PATCH 17/49] ath11k: add dp_rx.c Kalle Valo
2019-08-20 15:47   ` [PATCH 18/49] ath11k: add dp_rx.h Kalle Valo
2019-08-20 15:47   ` [PATCH 19/49] ath11k: add dp_tx.c Kalle Valo
2019-08-20 15:47   ` [PATCH 20/49] ath11k: add dp_tx.h Kalle Valo
2019-08-20 15:47   ` [PATCH 21/49] ath11k: add hal.c Kalle Valo
2019-08-20 15:47   ` [PATCH 22/49] ath11k: add hal.h Kalle Valo
2019-08-20 15:47   ` [PATCH 23/49] ath11k: add hal_desc.h Kalle Valo
2019-08-20 15:47   ` [PATCH 24/49] ath11k: add hal_rx.c Kalle Valo
2019-08-20 15:47   ` [PATCH 25/49] ath11k: add hal_rx.h Kalle Valo
2019-08-20 15:47   ` [PATCH 26/49] ath11k: add hal_tx.c Kalle Valo
2019-08-20 15:47   ` [PATCH 27/49] ath11k: add hal_tx.h Kalle Valo
2019-08-20 15:47   ` [PATCH 28/49] ath11k: add htc.c Kalle Valo
2019-08-20 15:47   ` [PATCH 29/49] ath11k: add htc.h Kalle Valo
2019-08-20 15:47   ` [PATCH 30/49] ath11k: add hw.h Kalle Valo
2019-08-20 15:47   ` [PATCH 31/49] ath11k: add mac.c Kalle Valo
     [not found]     ` <1566316095-27507-32-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-20 16:51       ` Toke Høiland-Jørgensen
     [not found]         ` <8736hvu6e6.fsf-LJ9M9ZcSy1A@public.gmane.org>
2019-08-21  5:02           ` Vasanthakumar Thiagarajan
     [not found]             ` <ac6e7dbbd53e7ba9e82e49baca22b73c-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-21 10:08               ` Toke Høiland-Jørgensen
     [not found]                 ` <875zmqsudn.fsf-LJ9M9ZcSy1A@public.gmane.org>
2019-08-27 10:43                   ` Vasanthakumar Thiagarajan
     [not found]                     ` <14737343f1925a771ddd8dadf0f2b5a3-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-27 17:27                       ` Toke Høiland-Jørgensen
     [not found]                         ` <87sgpmikne.fsf-LJ9M9ZcSy1A@public.gmane.org>
2019-08-27 19:13                           ` Ben Greear
2019-08-20 20:46       ` Johannes Berg
     [not found]         ` <4076919b34cad119eb4146025f587285ef40e37c.camel-cdvu00un1VgdHxzADdlk8Q@public.gmane.org>
2019-08-23 12:15           ` Vasanthakumar Thiagarajan
     [not found]             ` <ee38dc5e80097d0ebc186f81b2f11d37-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-09-05 11:24               ` Kalle Valo
     [not found]                 ` <878sr3nfz8.fsf-HodKDYzPHsUD5k0oWYwrnHL1okKdlPRT@public.gmane.org>
2019-09-05 11:58                   ` Vasanthakumar Thiagarajan
     [not found]                     ` <8e90a557c1659995d117c6dc8b728d7f-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-09-05 12:29                       ` Kalle Valo
     [not found]                         ` <87woenkjt7.fsf-HodKDYzPHsUD5k0oWYwrnHL1okKdlPRT@public.gmane.org>
2019-09-05 12:50                           ` Johannes Berg
2019-08-21  6:16       ` Sven Eckelmann
2019-08-23 15:02       ` Nicolas Cavallari
     [not found]         ` <c37a9fc4-aa74-a333-a67c-cce66ad78ec0-HoVSR7jCO9Dxoq/u1CTanTkwo1WHXZZs@public.gmane.org>
2019-08-27 10:51           ` Vasanthakumar Thiagarajan
2019-08-20 15:47   ` [PATCH 32/49] ath11k: add mac.h Kalle Valo
2019-08-20 15:47   ` [PATCH 33/49] ath11k: add peer.c Kalle Valo
2019-08-20 15:48   ` [PATCH 34/49] ath11k: add peer.h Kalle Valo
2019-08-20 15:48   ` [PATCH 35/49] ath11k: add qmi.c Kalle Valo
2019-08-20 15:48   ` [PATCH 36/49] ath11k: add qmi.h Kalle Valo
2019-08-20 15:48   ` [PATCH 37/49] ath11k: add reg.c Kalle Valo
2019-08-20 15:48   ` [PATCH 38/49] ath11k: add reg.h Kalle Valo
2019-08-20 15:48   ` [PATCH 39/49] ath11k: add rx_desc.h Kalle Valo
2019-08-20 15:48   ` [PATCH 40/49] ath11k: add testmode.c Kalle Valo
2019-08-20 15:48   ` [PATCH 41/49] ath11k: add testmode.h Kalle Valo
2019-08-20 15:48   ` [PATCH 42/49] ath11k: add testmode_i.h Kalle Valo
2019-08-20 15:48   ` [PATCH 43/49] ath11k: add trace.c Kalle Valo
2019-08-20 15:48   ` [PATCH 44/49] ath11k: add trace.h Kalle Valo
2019-08-20 15:48   ` [PATCH 45/49] ath11k: add wmi.c Kalle Valo
2019-08-20 15:48   ` [PATCH 46/49] ath11k: add wmi.h Kalle Valo
     [not found]     ` <1566316095-27507-47-git-send-email-kvalo-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>
2019-08-20 20:29       ` Johannes Berg
     [not found]         ` <c60afe716cc9ce3b511d8be0b04958342dfea908.camel-cdvu00un1VgdHxzADdlk8Q@public.gmane.org>
2019-08-23  4:21           ` Vasanthakumar Thiagarajan
2019-08-20 15:48   ` [PATCH 47/49] ath: add ath11k to Makefile Kalle Valo
2019-08-20 15:48   ` [PATCH 48/49] ath: add ath11k to Kconfig Kalle Valo
2019-08-20 15:48   ` [PATCH 49/49] MAINTAINERS: add ath11k Kalle Valo

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1566316095-27507-8-git-send-email-kvalo@codeaurora.org \
    --to=kvalo-sgv2jx0feol9jmxxk+q4oq@public.gmane.org \
    --cc=ath11k-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org \
    --cc=devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-wireless-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).