Lines Matching +full:wait +full:- +full:queue

7  * Copyright (c) 2003-2008 Cavium Networks
14 * AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty
21 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
31 * New, starting with SDK 1.7.0, cvmx-pow supports a number of
36 * enabled. For example, cvmx-pow will check for the following
38 * - Requesting a POW operation with an active tag switch in
40 * - Waiting for a tag switch to complete for an excessively
43 * - Illegal tag switches from NULL_NULL.
44 * - Illegal tag switches from NULL.
45 * - Illegal deschedule request.
46 * - WQE pointer not matching the one attached to the core by
54 #include <asm/octeon/cvmx-pow-defs.h>
56 #include <asm/octeon/cvmx-scratch.h>
57 #include <asm/octeon/cvmx-wqe.h>
70 * The work queue entry from the order - NEVER tag switch from
75 * - NEVER tag switch to NULL_NULL
76 * - NEVER tag switch from NULL_NULL
77 * - NULL_NULL is entered at the beginning of time and on a deschedule.
78 * - NULL_NULL can be exited by a new work request. A NULL_SWITCH
85 * Wait flag values for pow functions.
98 * - the previous tag should be non-NULL in this case
99 * - tag switch response required
100 * - fields used: op, type, tag
105 * - this should be used when the previous tag is NULL
106 * - tag switch response required
107 * - fields used: address, op, grp, type, tag
111 * switch the tag (and/or group) for this PP and de-schedule
112 * - OK to keep the tag the same and only change the group
113 * - fields used: op, no_sched, grp, type, tag
117 * just de-schedule
118 * - fields used: op, no_sched
122 * create an entirely new work queue entry
123 * - fields used: address, op, qos, grp, type, tag
127 * just update the work queue pointer and grp for this PP
128 * - fields used: address, op, grp
132 * set the no_sched bit on the de-schedule list
134 * - does nothing if the selected entry is not on the
135 * de-schedule list
137 * - does nothing if the stored work queue pointer does not
140 * - fields used: address, index, op
152 * clears the no_sched bit on the de-schedule list
154 * - does nothing if the selected entry is not on the
155 * de-schedule list
157 * - does nothing if the stored work queue pointer does not
160 * - fields used: address, index, op
200 * The group that the work queue entry will be
252 /* the ID of POW -- did<2:0> == 0 in this case */
260 uint64_t wait:1; member
265 uint64_t wait:1;
285 /* the ID of POW -- did<2:0> == 1 in this case */
292 * If set and get_cur is set, return reverse tag-list
293 * pointer rather than forward tag-list pointer.
302 * If set, get the work-queue pointer rather than
333 /* the ID of POW -- did<2:0> == 2 in this case */
341 * the standard response for work-queue index (invalid
342 * if the work-queue entry is not on the deschedule
347 * If set, get the work-queue pointer rather than
377 /* the ID of POW -- did<2:0> == 3 in this case */
383 * field selects one of eight POW internal-input
384 * queues (0-7), one per QOS level; values 8-15 are
388 * this field selects one of 16 memory-input queue
389 * lists. The two memory-input queue lists associated
392 * - qosgrp = 0, qosgrp = 8: QOS0
393 * - qosgrp = 1, qosgrp = 9: QOS1
394 * - qosgrp = 2, qosgrp = 10: QOS2
395 * - qosgrp = 3, qosgrp = 11: QOS3
396 * - qosgrp = 4, qosgrp = 12: QOS4
397 * - qosgrp = 5, qosgrp = 13: QOS5
398 * - qosgrp = 6, qosgrp = 14: QOS6
399 * - qosgrp = 7, qosgrp = 15: QOS7
434 * not available - software may need to recover by finishing
446 /* the ID of POW -- did<2:0> == 4 in this case */
473 * Set when no new work queue entry was returned. *
474 * If there was de-scheduled work, the HW will
478 * - There was no work, or
480 * - There was no work that the HW could find. This
481 * case can happen, regardless of the wait bit value
488 /* 36 in O1 -- the work queue pointer */
503 /* Set when there is a pending non-NULL SWTAG or
527 * the wait bit was set.
549 * - this is the tag when pend_switch or (pend_desched
581 * Set when there is a pending non-NULL SWTAG or
609 * the wait bit was set.
1150 * - CVMX_POW_TAG_TYPE_ORDERED
1151 * - CVMX_POW_TAG_TYPE_ATOMIC
1152 * - CVMX_POW_TAG_TYPE_NULL
1153 * - CVMX_POW_TAG_TYPE_NULL_NULL
1167 * hardware assumes that an aligned 64-bit store was used for all
1168 * these stores. Note the assumption that the work queue entry is
1169 * aligned on an 8-byte boundary (since the low-order 3 address bits
1175 * - did<2:0> == 0 => pending switch bit is set
1176 * - did<2:0> == 1 => no affect on the pending switch bit
1177 * - did<2:0> == 3 => pending switch bit is cleared
1178 * - did<2:0> == 7 => no affect on the pending switch bit
1179 * - did<2:0> == others => must not be used
1180 * - No other loads/stores have an affect on the pending switch bit
1181 * - The switch bus from POW can clear the pending switch bit
1183 * NOTE: did<2:0> == 2 is used by the HW for a special single-cycle
1199 /* Device ID of POW. Note that different sub-dids are used. */
1224 * the (64-bit word) location in scratchpad to write
1230 /* the ID of the device on the non-coherent bus */
1234 uint64_t wait:1; member
1238 uint64_t wait:1;
1248 /* CSR typedefs have been moved to cvmx-csr-*.h */
1281 * Get the POW WQE for this core. This returns the work queue
1335 start_cycle = -MAX_CYCLES - 1; in cvmx_pow_tag_sw_wait()
1342 * This function does NOT wait for previous tag switches to complete,
1345 * @wait: When set, call stalls until work becomes available, or times out.
1352 wait) in cvmx_pow_work_request_sync_nocheck()
1364 ptr.swork.wait = wait; in cvmx_pow_work_request_sync_nocheck()
1379 * @wait: When set, call stalls until work becomes available, or times out.
1385 static inline struct cvmx_wqe *cvmx_pow_work_request_sync(cvmx_pow_wait_t wait) in cvmx_pow_work_request_sync() argument
1392 return cvmx_pow_work_request_sync_nocheck(wait); in cvmx_pow_work_request_sync()
1427 * cvmx_pow_work_response_async. This function does NOT wait for
1435 * @wait: 1 to cause response to wait for work to become available (or
1439 cvmx_pow_wait_t wait) in cvmx_pow_work_request_async_nocheck() argument
1450 data.s.wait = wait; in cvmx_pow_work_request_async_nocheck()
1464 * @wait: 1 to cause response to wait for work to become available (or
1468 cvmx_pow_wait_t wait) in cvmx_pow_work_request_async() argument
1475 cvmx_pow_work_request_async_nocheck(scr_addr, wait); in cvmx_pow_work_request_async()
1480 * to wait for the response.
1502 * Checks if a work queue entry pointer returned by a work
1506 * @wqe_ptr: pointer to a work queue entry returned by the POW
1519 * function does NOT update the work queue entry in dram to match tag
1576 software must wait for the switch to complete separately */ in cvmx_pow_tag_sw_nocheck()
1583 * function does NOT update the work queue entry in dram to match tag
1624 * function does NOT update the work queue entry in dram to match tag
1635 * @wqp: pointer to work queue entry to submit. This entry is
1637 * @tag: tag value to be assigned to work queue entry
1639 * @group: group value for the work queue entry.
1690 * software must wait for the switch to complete separately. in cvmx_pow_tag_sw_full_nocheck()
1698 * function does NOT update the work queue entry in dram to match tag
1709 * @wqp: pointer to work queue entry to submit. This entry is updated
1711 * @tag: tag value to be assigned to work queue entry
1713 * @group: group value for the work queue entry.
1734 * work queue entry. This operation completes immediately,
1736 * This function does NOT wait for previous tag switches to complete,
1772 * work queue entry. This operation completes immediately,
1794 * Submits work to an input queue. This function updates the work
1795 * queue entry in DRAM to match the arguments given. Note that the
1796 * tag provided is for the work queue entry submitted, and is
1799 * @wqp: pointer to work queue entry to submit. This entry is
1801 * @tag: tag value to be assigned to work queue entry
1803 * @qos: Input queue to add to.
1804 * @grp: group value for the work queue entry.
1813 wqp->word1.tag = tag; in cvmx_pow_work_submit()
1814 wqp->word1.tag_type = tag_type; in cvmx_pow_work_submit()
1846 * @mask: Group mask. There are 16 groups, so only bits 0-15 are valid,
1847 * representing groups 0-15.
1861 * This function sets POW static priorities for a core. Each input queue has
1865 * @priority: Vector of 8 priorities, one per POW Input Queue (0-7).
1867 * of 0xF instructs POW to skip the Input Queue when
1899 if (prio_mask ^ ((1 << cvmx_pop(prio_mask)) - 1)) { in cvmx_pow_set_priority()
1916 * This function does NOT wait for any prior tag switches to complete, so the
1920 * re-scheduling DE-SCHEDULEd items whose (next) state is
1922 * - If there are no switches pending at the time that the
1923 * HW executes the de-schedule, the HW will only re-schedule
1931 * - If there is a pending switch to ORDERED at the time
1932 * the HW executes the de-schedule, the HW will perform
1933 * the switch at the time it re-schedules, and will be
1938 * DE-SCHEDULE. If an ORDERED tag is what was really desired,
1940 * after the work (that has an ATOMIC tag) is re-scheduled.
1942 * when the HW re-schedules, this switch can be IMMEDIATE upon
1943 * the reception of the pointer during the re-schedule.
1948 * @no_sched: Control whether this work queue entry will be rescheduled.
1949 * - 1 : don't schedule this work
1950 * - 0 : allow this work to be scheduled.
2003 * re-scheduling DE-SCHEDULEd items whose (next) state is
2005 * - If there are no switches pending at the time that the
2006 * HW executes the de-schedule, the HW will only re-schedule
2014 * - If there is a pending switch to ORDERED at the time
2015 * the HW executes the de-schedule, the HW will perform
2016 * the switch at the time it re-schedules, and will be
2021 * DE-SCHEDULE. If an ORDERED tag is what was really desired,
2023 * after the work (that has an ATOMIC tag) is re-scheduled.
2025 * when the HW re-schedules, this switch can be IMMEDIATE upon
2026 * the reception of the pointer during the re-schedule.
2031 * @no_sched: Control whether this work queue entry will be rescheduled.
2032 * - 1 : don't schedule this work
2033 * - 0 : allow this work to be scheduled.
2042 /* Need to make sure any writes to the work queue entry are complete */ in cvmx_pow_tag_sw_desched()
2054 * Deschedules the current work queue entry.
2056 * @no_sched: no schedule flag value to be set on the work queue
2076 /* Need to make sure any writes to the work queue entry are complete */ in cvmx_pow_desched()
2106 #define CVMX_TAG_SW_SHIFT (32 - CVMX_TAG_SW_BITS)
2115 * - the upper 8 bits (bits 23 - 16 of the tag) define a subgroup
2117 * - the lower 16 bits (bits 15 - 0 of the tag) define are the value
2121 * software - refer to the hardware documentation for a description of
2133 * The remaining values software bit values 0x2 - 0xff are available
2154 (hw_bits & cvmx_build_mask(32 - CVMX_TAG_SW_BITS)); in cvmx_pow_tag_compose()
2167 return (tag >> (32 - CVMX_TAG_SW_BITS)) & in cvmx_pow_tag_get_sw_bits()
2177 * Returns (32 - N) bit software tag value, where N is configurable
2182 return tag & cvmx_build_mask(32 - CVMX_TAG_SW_BITS); in cvmx_pow_tag_get_hw_bits()