Lines Matching +full:vl +full:- +full:supply

1 /* SPDX-License-Identifier: GPL-2.0 or BSD-3-Clause */
3 * Copyright(c) 2015 - 2018 Intel Corporation.
22 #define MAX_SDMA_PKT_SIZE ((16 * 1024) - 1)
61 ((1ULL << SDMA_DESC0_BYTE_COUNT_WIDTH) - 1)
67 ((1ULL << SDMA_DESC0_PHY_ADDR_WIDTH) - 1)
74 ((1ULL << SDMA_DESC1_HEADER_UPDATE1_WIDTH) - 1)
80 ((1ULL << SDMA_DESC1_HEADER_MODE_WIDTH) - 1)
86 ((1ULL << SDMA_DESC1_HEADER_INDEX_WIDTH) - 1)
92 ((1ULL << SDMA_DESC1_HEADER_DWS_WIDTH) - 1)
98 ((1ULL << SDMA_DESC1_GENERATION_WIDTH) - 1)
160 * - The SDMA API for building and submitting packets
163 * - Initialization and tear down routines to buildup
166 * - ISR entrances to handle interrupts, state changes
174 * and verbs to supply packets to the SDMA ring.
183 * for their version of the txreq. slabs, pre-allocated lists,
205 * tx. An example of a use case would be a pre-allocated
249 * struct hw_sdma_desc - raw 128 bit SDMA descriptor
259 * struct sdma_engine - Data pertaining to each SDMA engine.
260 * @dd: a back-pointer to the device data
261 * @ppd: per port back-pointer
304 u64 p_senddmactrl; /* shadow per-engine SendDmaCtrl */
383 * sdma_empty() - idle engine test
389 * 1 - empty, 0 - non-empty
393 return sde->descq_tail == sde->descq_head; in sdma_empty()
398 return sde->descq_cnt - in sdma_descq_freecnt()
399 (sde->descq_tail - in sdma_descq_freecnt()
400 READ_ONCE(sde->descq_head)) - 1; in sdma_descq_freecnt()
405 return sde->descq_cnt - sdma_descq_freecnt(sde); in sdma_descq_inprocess()
414 return engine->state.current_state == sdma_state_s99_running; in __sdma_running()
418 * sdma_running() - state suitability test
425 * 1 - ok to submit, 0 - not ok to submit
433 spin_lock_irqsave(&engine->tail_lock, flags); in sdma_running()
435 spin_unlock_irqrestore(&engine->tail_lock, flags); in sdma_running()
447 * sdma_txinit_ahg() - initialize an sdma_txreq struct with AHG
451 * @ahg_entry: ahg entry to use (0 - 31)
452 * @num_ahg: ahg descriptor for first descriptor (0 - 9)
488 * will pad with a descriptor references 1 - 3 bytes when the number of bytes
491 * ahg_hlen is used to determine the number of on-chip entry bytes to
509 return -ENODATA; in sdma_txinit_ahg()
511 return -EMSGSIZE; in sdma_txinit_ahg()
512 tx->desc_limit = ARRAY_SIZE(tx->descs); in sdma_txinit_ahg()
513 tx->descp = &tx->descs[0]; in sdma_txinit_ahg()
514 INIT_LIST_HEAD(&tx->list); in sdma_txinit_ahg()
515 tx->num_desc = 0; in sdma_txinit_ahg()
516 tx->flags = flags; in sdma_txinit_ahg()
517 tx->complete = cb; in sdma_txinit_ahg()
518 tx->coalesce_buf = NULL; in sdma_txinit_ahg()
519 tx->wait = NULL; in sdma_txinit_ahg()
520 tx->packet_len = tlen; in sdma_txinit_ahg()
521 tx->tlen = tx->packet_len; in sdma_txinit_ahg()
522 tx->descs[0].qw[0] = SDMA_DESC0_FIRST_DESC_FLAG; in sdma_txinit_ahg()
523 tx->descs[0].qw[1] = 0; in sdma_txinit_ahg()
525 tx->descs[0].qw[1] |= in sdma_txinit_ahg()
536 * sdma_txinit() - initialize an sdma_txreq struct (no AHG)
561 * The callback, if non-NULL, will be provided this tx and a status. The
575 /* helpers - don't use */
578 return (d->qw[1] & SDMA_DESC1_GENERATION_SMASK) in sdma_mapping_type()
584 return (d->qw[0] & SDMA_DESC0_BYTE_COUNT_SMASK) in sdma_mapping_len()
590 return (d->qw[0] & SDMA_DESC0_PHY_ADDR_SMASK) in sdma_mapping_addr()
600 struct sdma_desc *desc = &tx->descp[tx->num_desc]; in make_tx_sdma_desc()
602 if (!tx->num_desc) { in make_tx_sdma_desc()
604 desc->qw[1] |= ((u64)type & SDMA_DESC1_GENERATION_MASK) in make_tx_sdma_desc()
607 desc->qw[0] = 0; in make_tx_sdma_desc()
608 desc->qw[1] = ((u64)type & SDMA_DESC1_GENERATION_MASK) in make_tx_sdma_desc()
611 desc->qw[0] |= (((u64)addr & SDMA_DESC0_PHY_ADDR_MASK) in make_tx_sdma_desc()
626 if (tx->num_desc) in sdma_txclean()
634 tx->descp[tx->num_desc].qw[0] |= in _sdma_close_tx()
636 tx->descp[tx->num_desc].qw[1] |= in _sdma_close_tx()
637 dd->default_desc1; in _sdma_close_tx()
638 if (tx->flags & SDMA_TXREQ_F_URGENT) in _sdma_close_tx()
639 tx->descp[tx->num_desc].qw[1] |= in _sdma_close_tx()
657 WARN_ON(len > tx->tlen); in _sdma_txadd_daddr()
658 tx->tlen -= len; in _sdma_txadd_daddr()
660 if (!tx->tlen) { in _sdma_txadd_daddr()
661 if (tx->packet_len & (sizeof(u32) - 1)) { in _sdma_txadd_daddr()
669 tx->num_desc++; in _sdma_txadd_daddr()
674 * sdma_txadd_page() - add a page to the sdma_txreq
686 * 0 - success, -ENOSPC - mapping fail, -ENOMEM - couldn't
699 if ((unlikely(tx->num_desc == tx->desc_limit))) { in sdma_txadd_page()
707 &dd->pcidev->dev, in sdma_txadd_page()
713 if (unlikely(dma_mapping_error(&dd->pcidev->dev, addr))) { in sdma_txadd_page()
715 return -ENOSPC; in sdma_txadd_page()
723 * sdma_txadd_daddr() - add a dma address to the sdma_txreq
735 * 0 - success, -ENOMEM - couldn't extend descriptor array
746 if ((unlikely(tx->num_desc == tx->desc_limit))) { in sdma_txadd_daddr()
757 * sdma_txadd_kvaddr() - add a kernel virtual address to sdma_txreq
769 * 0 - success, -ENOSPC - mapping fail, -ENOMEM - couldn't extend/coalesce
781 if ((unlikely(tx->num_desc == tx->desc_limit))) { in sdma_txadd_kvaddr()
789 &dd->pcidev->dev, in sdma_txadd_kvaddr()
794 if (unlikely(dma_mapping_error(&dd->pcidev->dev, addr))) { in sdma_txadd_kvaddr()
796 return -ENOSPC; in sdma_txadd_kvaddr()
818 * sdma_build_ahg - build ahg descriptor
844 * sdma_progress - use seq number of detect head progress
854 * re-submission is detected by checking whether the descriptor
860 if (read_seqretry(&sde->head_lock, seq)) { in sdma_progress()
861 sde->desc_avail = sdma_descq_freecnt(sde); in sdma_progress()
862 if (tx->num_desc > sde->desc_avail) in sdma_progress()
877 * Since the mapping now allows for non-uniform engines per vl, the
878 * number of engines for a vl is either the vl_engines[vl] or
882 * nactual = vl_engines ? vl_engines[vl] : num_sdma/num_vls
887 * evenly, the extras are added from the last vl downward.
891 * for a particular vl.
893 * dd->sdma_map
895 * | +--------------------+
897 * sdma_vl_map |--------------------|
898 * +--------------------------+ | sde[0] -> eng 1 |
899 * | list (RCU) | |--------------------|
900 * |--------------------------| ->| sde[1] -> eng 2 |
901 * | mask | --/ |--------------------|
902 * |--------------------------| -/ | * |
903 * | actual_vls (max 8) | -/ |--------------------|
904 * |--------------------------| --/ | sde[n-1] -> eng n |
905 * | vls (max 8) | -/ +--------------------+
906 * |--------------------------| --/
907 * | map[0] |-/
908 * |--------------------------| +---------------------+
909 * | map[1] |--- | mask |
910 * |--------------------------| \---- |---------------------|
911 * | * | \-- | sde[0] -> eng 1+n |
912 * | * | \---- |---------------------|
913 * | * | \->| sde[1] -> eng 2+n |
914 * |--------------------------| |---------------------|
915 * | map[vls - 1] |- | * |
916 * +--------------------------+ \- |---------------------|
917 * \- | sde[m-1] -> eng m+n |
918 * \ +---------------------+
919 * \-
921 * \- +----------------------+
922 * \- | mask |
923 * \ |----------------------|
924 * \- | sde[0] -> eng 1+m+n |
925 * \- |----------------------|
926 * >| sde[1] -> eng 2+m+n |
927 * |----------------------|
929 * |----------------------|
930 * | sde[o-1] -> eng o+m+n|
931 * +----------------------+
936 * struct sdma_map_elem - mapping for a vl
937 * @mask - selector mask
938 * @sde - array of engines for this vl
950 * struct sdma_map_el - mapping for a vl
951 * @engine_to_vl - map of an engine to a vl
952 * @list - rcu head for free callback
953 * @mask - vl mask to "mod" the vl to produce an index to map array
954 * @actual_vls - number of vls
955 * @vls - number of vls rounded to next power of 2
956 * @map - array of sdma_map_elem entries
960 * in turn point to an array of sde's for that vl.
981 * sdma_engine_progress_schedule() - schedule progress on engine
990 if (!sde || sdma_descq_inprocess(sde) < (sde->descq_cnt / 8)) in sdma_engine_progress_schedule()
1003 u8 vl);
1006 u32 selector, u8 vl);