xref: /openbmc/linux/drivers/net/ipa/ipa_data.h (revision e938d7ef)
11ed7d0c0SAlex Elder /* SPDX-License-Identifier: GPL-2.0 */
21ed7d0c0SAlex Elder 
31ed7d0c0SAlex Elder /* Copyright (c) 2012-2018, The Linux Foundation. All rights reserved.
41ed7d0c0SAlex Elder  * Copyright (C) 2019-2020 Linaro Ltd.
51ed7d0c0SAlex Elder  */
61ed7d0c0SAlex Elder #ifndef _IPA_DATA_H_
71ed7d0c0SAlex Elder #define _IPA_DATA_H_
81ed7d0c0SAlex Elder 
91ed7d0c0SAlex Elder #include <linux/types.h>
101ed7d0c0SAlex Elder 
111ed7d0c0SAlex Elder #include "ipa_version.h"
121ed7d0c0SAlex Elder #include "ipa_endpoint.h"
131ed7d0c0SAlex Elder #include "ipa_mem.h"
141ed7d0c0SAlex Elder 
151ed7d0c0SAlex Elder /**
161ed7d0c0SAlex Elder  * DOC: IPA/GSI Configuration Data
171ed7d0c0SAlex Elder  *
181ed7d0c0SAlex Elder  * Boot-time configuration data is used to define the configuration of the
191ed7d0c0SAlex Elder  * IPA and GSI resources to use for a given platform.  This data is supplied
201ed7d0c0SAlex Elder  * via the Device Tree match table, associated with a particular compatible
211ed7d0c0SAlex Elder  * string.  The data defines information about resources, endpoints, and
221ed7d0c0SAlex Elder  * channels.
231ed7d0c0SAlex Elder  *
241ed7d0c0SAlex Elder  * Resources are data structures used internally by the IPA hardware.  The
251ed7d0c0SAlex Elder  * configuration data defines the number (or limits of the number) of various
261ed7d0c0SAlex Elder  * types of these resources.
271ed7d0c0SAlex Elder  *
281ed7d0c0SAlex Elder  * Endpoint configuration data defines properties of both IPA endpoints and
291ed7d0c0SAlex Elder  * GSI channels.  A channel is a GSI construct, and represents a single
301ed7d0c0SAlex Elder  * communication path between the IPA and a particular execution environment
311ed7d0c0SAlex Elder  * (EE), such as the AP or Modem.  Each EE has a set of channels associated
321ed7d0c0SAlex Elder  * with it, and each channel has an ID unique for that EE.  For the most part
331ed7d0c0SAlex Elder  * the only GSI channels of concern to this driver belong to the AP
341ed7d0c0SAlex Elder  *
351ed7d0c0SAlex Elder  * An endpoint is an IPA construct representing a single channel anywhere
361ed7d0c0SAlex Elder  * in the system.  An IPA endpoint ID maps directly to an (EE, channel_id)
371ed7d0c0SAlex Elder  * pair.  Generally, this driver is concerned with only endpoints associated
381ed7d0c0SAlex Elder  * with the AP, however this will change when support for routing (etc.) is
391ed7d0c0SAlex Elder  * added.  IPA endpoint and GSI channel configuration data are defined
401ed7d0c0SAlex Elder  * together, establishing the endpoint_id->(EE, channel_id) mapping.
411ed7d0c0SAlex Elder  *
421ed7d0c0SAlex Elder  * Endpoint configuration data consists of three parts:  properties that
431ed7d0c0SAlex Elder  * are common to IPA and GSI (EE ID, channel ID, endpoint ID, and direction);
441ed7d0c0SAlex Elder  * properties associated with the GSI channel; and properties associated with
451ed7d0c0SAlex Elder  * the IPA endpoint.
461ed7d0c0SAlex Elder  */
471ed7d0c0SAlex Elder 
488c365f74SAlex Elder /* The maximum value returned by ipa_resource_group_{src,dst}_count() */
49624251b4SAlex Elder #define IPA_RESOURCE_GROUP_SRC_MAX	5
50624251b4SAlex Elder #define IPA_RESOURCE_GROUP_DST_MAX	5
511ed7d0c0SAlex Elder 
521ed7d0c0SAlex Elder /**
531ed7d0c0SAlex Elder  * struct gsi_channel_data - GSI channel configuration data
541ed7d0c0SAlex Elder  * @tre_count:		number of TREs in the channel ring
551ed7d0c0SAlex Elder  * @event_count:	number of slots in the associated event ring
561ed7d0c0SAlex Elder  * @tlv_count:		number of entries in channel's TLV FIFO
571ed7d0c0SAlex Elder  *
581ed7d0c0SAlex Elder  * A GSI channel is a unidirectional means of transferring data to or
591ed7d0c0SAlex Elder  * from (and through) the IPA.  A GSI channel has a ring buffer made
601ed7d0c0SAlex Elder  * up of "transfer elements" (TREs) that specify individual data transfers
611ed7d0c0SAlex Elder  * or IPA immediate commands.  TREs are filled by the AP, and control
621ed7d0c0SAlex Elder  * is passed to IPA hardware by writing the last written element
631ed7d0c0SAlex Elder  * into a doorbell register.
641ed7d0c0SAlex Elder  *
651ed7d0c0SAlex Elder  * When data transfer commands have completed the GSI generates an
661ed7d0c0SAlex Elder  * event (a structure of data) and optionally signals the AP with
671ed7d0c0SAlex Elder  * an interrupt.  Event structures are implemented by another ring
681ed7d0c0SAlex Elder  * buffer, directed toward the AP from the IPA.
691ed7d0c0SAlex Elder  *
701ed7d0c0SAlex Elder  * The input to a GSI channel is a FIFO of type/length/value (TLV)
711ed7d0c0SAlex Elder  * elements, and the size of this FIFO limits the number of TREs
721ed7d0c0SAlex Elder  * that can be included in a single transaction.
731ed7d0c0SAlex Elder  */
741ed7d0c0SAlex Elder struct gsi_channel_data {
751ed7d0c0SAlex Elder 	u16 tre_count;
761ed7d0c0SAlex Elder 	u16 event_count;
771ed7d0c0SAlex Elder 	u8 tlv_count;
781ed7d0c0SAlex Elder };
791ed7d0c0SAlex Elder 
801ed7d0c0SAlex Elder /**
811ed7d0c0SAlex Elder  * struct ipa_endpoint_tx_data - configuration data for TX endpoints
821ed7d0c0SAlex Elder  * @status_endpoint:	endpoint to which status elements are sent
831ed7d0c0SAlex Elder  *
841ed7d0c0SAlex Elder  * The @status_endpoint is only valid if the endpoint's @status_enable
851ed7d0c0SAlex Elder  * flag is set.
861ed7d0c0SAlex Elder  */
871ed7d0c0SAlex Elder struct ipa_endpoint_tx_data {
881ed7d0c0SAlex Elder 	enum ipa_endpoint_name status_endpoint;
891ed7d0c0SAlex Elder };
901ed7d0c0SAlex Elder 
911ed7d0c0SAlex Elder /**
921ed7d0c0SAlex Elder  * struct ipa_endpoint_rx_data - configuration data for RX endpoints
931ed7d0c0SAlex Elder  * @pad_align:	power-of-2 boundary to which packet payload is aligned
941ed7d0c0SAlex Elder  * @aggr_close_eof: whether aggregation closes on end-of-frame
951ed7d0c0SAlex Elder  *
961ed7d0c0SAlex Elder  * With each packet it transfers, the IPA hardware can perform certain
971ed7d0c0SAlex Elder  * transformations of its packet data.  One of these is adding pad bytes
981ed7d0c0SAlex Elder  * to the end of the packet data so the result ends on a power-of-2 boundary.
991ed7d0c0SAlex Elder  *
1001ed7d0c0SAlex Elder  * It is also able to aggregate multiple packets into a single receive buffer.
1011ed7d0c0SAlex Elder  * Aggregation is "open" while a buffer is being filled, and "closes" when
1021ed7d0c0SAlex Elder  * certain criteria are met.  One of those criteria is the sender indicating
1031ed7d0c0SAlex Elder  * a "frame" consisting of several transfers has ended.
1041ed7d0c0SAlex Elder  */
1051ed7d0c0SAlex Elder struct ipa_endpoint_rx_data {
1061ed7d0c0SAlex Elder 	u32 pad_align;
1071ed7d0c0SAlex Elder 	bool aggr_close_eof;
1081ed7d0c0SAlex Elder };
1091ed7d0c0SAlex Elder 
1101ed7d0c0SAlex Elder /**
1111ed7d0c0SAlex Elder  * struct ipa_endpoint_config_data - IPA endpoint hardware configuration
1122d265342SAlex Elder  * @resource_group:	resource group to assign endpoint to
1131ed7d0c0SAlex Elder  * @checksum:		whether checksum offload is enabled
1141ed7d0c0SAlex Elder  * @qmap:		whether endpoint uses QMAP protocol
1151ed7d0c0SAlex Elder  * @aggregation:	whether endpoint supports aggregation
1161ed7d0c0SAlex Elder  * @status_enable:	whether endpoint uses status elements
1171ed7d0c0SAlex Elder  * @dma_mode:		whether endpoint operates in DMA mode
1181ed7d0c0SAlex Elder  * @dma_endpoint:	peer endpoint, if operating in DMA mode
1191ed7d0c0SAlex Elder  * @tx:			TX-specific endpoint information (see above)
1201ed7d0c0SAlex Elder  * @rx:			RX-specific endpoint information (see above)
1211ed7d0c0SAlex Elder  */
1221ed7d0c0SAlex Elder struct ipa_endpoint_config_data {
1232d265342SAlex Elder 	u32 resource_group;
1241ed7d0c0SAlex Elder 	bool checksum;
1251ed7d0c0SAlex Elder 	bool qmap;
1261ed7d0c0SAlex Elder 	bool aggregation;
1271ed7d0c0SAlex Elder 	bool status_enable;
1281ed7d0c0SAlex Elder 	bool dma_mode;
1291ed7d0c0SAlex Elder 	enum ipa_endpoint_name dma_endpoint;
1301ed7d0c0SAlex Elder 	union {
1311ed7d0c0SAlex Elder 		struct ipa_endpoint_tx_data tx;
1321ed7d0c0SAlex Elder 		struct ipa_endpoint_rx_data rx;
1331ed7d0c0SAlex Elder 	};
1341ed7d0c0SAlex Elder };
1351ed7d0c0SAlex Elder 
1361ed7d0c0SAlex Elder /**
1371ed7d0c0SAlex Elder  * struct ipa_endpoint_data - IPA endpoint configuration data
1381ed7d0c0SAlex Elder  * @filter_support:	whether endpoint supports filtering
1391ed7d0c0SAlex Elder  * @seq_type:		hardware sequencer type used for endpoint
1401ed7d0c0SAlex Elder  * @config:		hardware configuration (see above)
1411ed7d0c0SAlex Elder  *
1421ed7d0c0SAlex Elder  * Not all endpoints support the IPA filtering capability.  A filter table
1431ed7d0c0SAlex Elder  * defines the filters to apply for those endpoints that support it.  The
1441ed7d0c0SAlex Elder  * AP is responsible for initializing this table, and it must include entries
1451ed7d0c0SAlex Elder  * for non-AP endpoints.  For this reason we define *all* endpoints used
1461ed7d0c0SAlex Elder  * in the system, and indicate whether they support filtering.
1471ed7d0c0SAlex Elder  *
1481ed7d0c0SAlex Elder  * The remaining endpoint configuration data applies only to AP endpoints.
1491ed7d0c0SAlex Elder  * The IPA hardware is implemented by sequencers, and the AP must program
1501ed7d0c0SAlex Elder  * the type(s) of these sequencers at initialization time.  The remaining
1511ed7d0c0SAlex Elder  * endpoint configuration data is defined above.
1521ed7d0c0SAlex Elder  */
1531ed7d0c0SAlex Elder struct ipa_endpoint_data {
1541ed7d0c0SAlex Elder 	bool filter_support;
1551ed7d0c0SAlex Elder 	/* The next two are specified only for AP endpoints */
1561ed7d0c0SAlex Elder 	enum ipa_seq_type seq_type;
1571ed7d0c0SAlex Elder 	struct ipa_endpoint_config_data config;
1581ed7d0c0SAlex Elder };
1591ed7d0c0SAlex Elder 
1601ed7d0c0SAlex Elder /**
1611ed7d0c0SAlex Elder  * struct ipa_gsi_endpoint_data - GSI channel/IPA endpoint data
1621ed7d0c0SAlex Elder  * ee:		GSI execution environment ID
1631ed7d0c0SAlex Elder  * channel_id:	GSI channel ID
1641ed7d0c0SAlex Elder  * endpoint_id:	IPA endpoint ID
1651ed7d0c0SAlex Elder  * toward_ipa:	direction of data transfer
1661ed7d0c0SAlex Elder  * gsi:		GSI channel configuration data (see above)
1671ed7d0c0SAlex Elder  * ipa:		IPA endpoint configuration data (see above)
1681ed7d0c0SAlex Elder  */
1691ed7d0c0SAlex Elder struct ipa_gsi_endpoint_data {
1701ed7d0c0SAlex Elder 	u8 ee_id;		/* enum gsi_ee_id */
1711ed7d0c0SAlex Elder 	u8 channel_id;
1721ed7d0c0SAlex Elder 	u8 endpoint_id;
1731ed7d0c0SAlex Elder 	bool toward_ipa;
1741ed7d0c0SAlex Elder 
1751ed7d0c0SAlex Elder 	struct gsi_channel_data channel;
1761ed7d0c0SAlex Elder 	struct ipa_endpoint_data endpoint;
1771ed7d0c0SAlex Elder };
1781ed7d0c0SAlex Elder 
1791ed7d0c0SAlex Elder /** enum ipa_resource_type_src - source resource types */
1801ed7d0c0SAlex Elder enum ipa_resource_type_src {
1811ed7d0c0SAlex Elder 	IPA_RESOURCE_TYPE_SRC_PKT_CONTEXTS,
1821ed7d0c0SAlex Elder 	IPA_RESOURCE_TYPE_SRC_DESCRIPTOR_LISTS,
1831ed7d0c0SAlex Elder 	IPA_RESOURCE_TYPE_SRC_DESCRIPTOR_BUFF,
1841ed7d0c0SAlex Elder 	IPA_RESOURCE_TYPE_SRC_HPS_DMARS,
1851ed7d0c0SAlex Elder 	IPA_RESOURCE_TYPE_SRC_ACK_ENTRIES,
1861ed7d0c0SAlex Elder };
1871ed7d0c0SAlex Elder 
1881ed7d0c0SAlex Elder /** enum ipa_resource_type_dst - destination resource types */
1891ed7d0c0SAlex Elder enum ipa_resource_type_dst {
1901ed7d0c0SAlex Elder 	IPA_RESOURCE_TYPE_DST_DATA_SECTORS,
1911ed7d0c0SAlex Elder 	IPA_RESOURCE_TYPE_DST_DPS_DMARS,
1921ed7d0c0SAlex Elder };
1931ed7d0c0SAlex Elder 
1941ed7d0c0SAlex Elder /**
1951ed7d0c0SAlex Elder  * struct ipa_resource_limits - minimum and maximum resource counts
1961ed7d0c0SAlex Elder  * @min:	minimum number of resources of a given type
1971ed7d0c0SAlex Elder  * @max:	maximum number of resources of a given type
1981ed7d0c0SAlex Elder  */
1991ed7d0c0SAlex Elder struct ipa_resource_limits {
2001ed7d0c0SAlex Elder 	u32 min;
2011ed7d0c0SAlex Elder 	u32 max;
2021ed7d0c0SAlex Elder };
2031ed7d0c0SAlex Elder 
2041ed7d0c0SAlex Elder /**
2051ed7d0c0SAlex Elder  * struct ipa_resource_src - source endpoint group resource usage
2061ed7d0c0SAlex Elder  * @type:	source group resource type
2071ed7d0c0SAlex Elder  * @limits:	array of limits to use for each resource group
2081ed7d0c0SAlex Elder  */
2091ed7d0c0SAlex Elder struct ipa_resource_src {
2101ed7d0c0SAlex Elder 	enum ipa_resource_type_src type;
2118c365f74SAlex Elder 	struct ipa_resource_limits limits[IPA_RESOURCE_GROUP_SRC_MAX];
2121ed7d0c0SAlex Elder };
2131ed7d0c0SAlex Elder 
2141ed7d0c0SAlex Elder /**
2151ed7d0c0SAlex Elder  * struct ipa_resource_dst - destination endpoint group resource usage
2161ed7d0c0SAlex Elder  * @type:	destination group resource type
2171ed7d0c0SAlex Elder  * @limits:	array of limits to use for each resource group
2181ed7d0c0SAlex Elder  */
2191ed7d0c0SAlex Elder struct ipa_resource_dst {
2201ed7d0c0SAlex Elder 	enum ipa_resource_type_dst type;
2218c365f74SAlex Elder 	struct ipa_resource_limits limits[IPA_RESOURCE_GROUP_DST_MAX];
2221ed7d0c0SAlex Elder };
2231ed7d0c0SAlex Elder 
2241ed7d0c0SAlex Elder /**
2251ed7d0c0SAlex Elder  * struct ipa_resource_data - IPA resource configuration data
2261ed7d0c0SAlex Elder  * @resource_src_count:	number of entries in the resource_src array
2271ed7d0c0SAlex Elder  * @resource_src:	source endpoint group resources
2281ed7d0c0SAlex Elder  * @resource_dst_count:	number of entries in the resource_dst array
2291ed7d0c0SAlex Elder  * @resource_dst:	destination endpoint group resources
2301ed7d0c0SAlex Elder  *
2311ed7d0c0SAlex Elder  * In order to manage quality of service between endpoints, certain resources
2321ed7d0c0SAlex Elder  * required for operation are allocated to groups of endpoints.  Generally
2331ed7d0c0SAlex Elder  * this information is invisible to the AP, but the AP is responsible for
2341ed7d0c0SAlex Elder  * programming it at initialization time, so we specify it here.
2351ed7d0c0SAlex Elder  */
2361ed7d0c0SAlex Elder struct ipa_resource_data {
2371ed7d0c0SAlex Elder 	u32 resource_src_count;
2381ed7d0c0SAlex Elder 	const struct ipa_resource_src *resource_src;
2391ed7d0c0SAlex Elder 	u32 resource_dst_count;
2401ed7d0c0SAlex Elder 	const struct ipa_resource_dst *resource_dst;
2411ed7d0c0SAlex Elder };
2421ed7d0c0SAlex Elder 
2431ed7d0c0SAlex Elder /**
244dfccb8b1SAlex Elder  * struct ipa_mem_data - description of IPA memory regions
2453128aae8SAlex Elder  * @local_count:	number of regions defined in the local[] array
2463128aae8SAlex Elder  * @local:		array of IPA-local memory region descriptors
2473e313c3fSAlex Elder  * @imem_addr:		physical address of IPA region within IMEM
2483e313c3fSAlex Elder  * @imem_size:		size in bytes of IPA IMEM region
249a0036bb4SAlex Elder  * @smem_id:		item identifier for IPA region within SMEM memory
250a0036bb4SAlex Elder  * @imem_size:		size in bytes of the IPA SMEM region
2511ed7d0c0SAlex Elder  */
2521ed7d0c0SAlex Elder struct ipa_mem_data {
2533128aae8SAlex Elder 	u32 local_count;
2543128aae8SAlex Elder 	const struct ipa_mem *local;
2553e313c3fSAlex Elder 	u32 imem_addr;
2563e313c3fSAlex Elder 	u32 imem_size;
257a0036bb4SAlex Elder 	u32 smem_id;
258a0036bb4SAlex Elder 	u32 smem_size;
2591ed7d0c0SAlex Elder };
2601ed7d0c0SAlex Elder 
261dfccb8b1SAlex Elder /** enum ipa_interconnect_id - IPA interconnect identifier */
262dfccb8b1SAlex Elder enum ipa_interconnect_id {
263dfccb8b1SAlex Elder 	IPA_INTERCONNECT_MEMORY,
264dfccb8b1SAlex Elder 	IPA_INTERCONNECT_IMEM,
265dfccb8b1SAlex Elder 	IPA_INTERCONNECT_CONFIG,
266dfccb8b1SAlex Elder 	IPA_INTERCONNECT_COUNT,		/* Last; not an interconnect */
267dfccb8b1SAlex Elder };
268dfccb8b1SAlex Elder 
269dfccb8b1SAlex Elder /**
270bf52e27bSAlex Elder  * struct ipa_interconnect_data - description of IPA interconnect bandwidths
271*e938d7efSAlex Elder  * @name:		Interconnect name (matches interconnect-name in DT)
272bf52e27bSAlex Elder  * @peak_bandwidth:	Peak interconnect bandwidth (in 1000 byte/sec units)
273bf52e27bSAlex Elder  * @average_bandwidth:	Average interconnect bandwidth (in 1000 byte/sec units)
274dfccb8b1SAlex Elder  */
275dfccb8b1SAlex Elder struct ipa_interconnect_data {
276*e938d7efSAlex Elder 	const char *name;
277bf52e27bSAlex Elder 	u32 peak_bandwidth;
278bf52e27bSAlex Elder 	u32 average_bandwidth;
279dfccb8b1SAlex Elder };
280dfccb8b1SAlex Elder 
281dfccb8b1SAlex Elder /**
282dfccb8b1SAlex Elder  * struct ipa_clock_data - description of IPA clock and interconnect rates
283dfccb8b1SAlex Elder  * @core_clock_rate:	Core clock rate (Hz)
284dfccb8b1SAlex Elder  * @interconnect:	Array of interconnect bandwidth parameters
285dfccb8b1SAlex Elder  */
286dfccb8b1SAlex Elder struct ipa_clock_data {
287dfccb8b1SAlex Elder 	u32 core_clock_rate;
288dfccb8b1SAlex Elder 	struct ipa_interconnect_data interconnect[IPA_INTERCONNECT_COUNT];
289dfccb8b1SAlex Elder };
290dfccb8b1SAlex Elder 
2911ed7d0c0SAlex Elder /**
2921ed7d0c0SAlex Elder  * struct ipa_data - combined IPA/GSI configuration data
2931ed7d0c0SAlex Elder  * @version:		IPA hardware version
2941ed7d0c0SAlex Elder  * @endpoint_count:	number of entries in endpoint_data array
2951ed7d0c0SAlex Elder  * @endpoint_data:	IPA endpoint/GSI channel data
2961ed7d0c0SAlex Elder  * @resource_data:	IPA resource configuration data
2971ed7d0c0SAlex Elder  * @mem_count:		number of entries in mem_data array
2981ed7d0c0SAlex Elder  * @mem_data:		IPA-local shared memory region data
2991ed7d0c0SAlex Elder  */
3001ed7d0c0SAlex Elder struct ipa_data {
3011ed7d0c0SAlex Elder 	enum ipa_version version;
3021ed7d0c0SAlex Elder 	u32 endpoint_count;	/* # entries in endpoint_data[] */
3031ed7d0c0SAlex Elder 	const struct ipa_gsi_endpoint_data *endpoint_data;
3041ed7d0c0SAlex Elder 	const struct ipa_resource_data *resource_data;
3053128aae8SAlex Elder 	const struct ipa_mem_data *mem_data;
306dfccb8b1SAlex Elder 	const struct ipa_clock_data *clock_data;
3071ed7d0c0SAlex Elder };
3081ed7d0c0SAlex Elder 
3091ed7d0c0SAlex Elder extern const struct ipa_data ipa_data_sdm845;
3101ed7d0c0SAlex Elder extern const struct ipa_data ipa_data_sc7180;
3111ed7d0c0SAlex Elder 
3121ed7d0c0SAlex Elder #endif /* _IPA_DATA_H_ */
313