| /Linux-v6.6/kernel/sched/ | 
| D | completion.c | 1 // SPDX-License-Identifier: GPL-2.04  * Generic wait-for-completion handler;
 7  * wait_for_completion default blocks whereas semaphore default non-block. The
 20 	raw_spin_lock_irqsave(&x->wait.lock, flags);  in complete_with_flags()
 22 	if (x->done != UINT_MAX)  in complete_with_flags()
 23 		x->done++;  in complete_with_flags()
 24 	swake_up_locked(&x->wait, wake_flags);  in complete_with_flags()
 25 	raw_spin_unlock_irqrestore(&x->wait.lock, flags);  in complete_with_flags()
 34  * complete: - signals a single thread waiting on this completion
 35  * @x:  holds the state of this particular completion
 [all …]
 
 | 
| D | swait.c | 1 // SPDX-License-Identifier: GPL-2.03  * <linux/swait.h> (simple wait queues ) implementation:
 9 	raw_spin_lock_init(&q->lock);  in __init_swait_queue_head()
 10 	lockdep_set_class_and_name(&q->lock, key, name);  in __init_swait_queue_head()
 11 	INIT_LIST_HEAD(&q->task_list);  in __init_swait_queue_head()
 25 	if (list_empty(&q->task_list))  in swake_up_locked()
 28 	curr = list_first_entry(&q->task_list, typeof(*curr), task_list);  in swake_up_locked()
 29 	try_to_wake_up(curr->task, TASK_NORMAL, wake_flags);  in swake_up_locked()
 30 	list_del_init(&curr->task_list);  in swake_up_locked()
 43 	while (!list_empty(&q->task_list))  in swake_up_all_locked()
 [all …]
 
 | 
| D | wait.c | 1 // SPDX-License-Identifier: GPL-2.0-only10 	spin_lock_init(&wq_head->lock);  in __init_waitqueue_head()
 11 	lockdep_set_class_and_name(&wq_head->lock, key, name);  in __init_waitqueue_head()
 12 	INIT_LIST_HEAD(&wq_head->head);  in __init_waitqueue_head()
 21 	wq_entry->flags &= ~WQ_FLAG_EXCLUSIVE;  in add_wait_queue()
 22 	spin_lock_irqsave(&wq_head->lock, flags);  in add_wait_queue()
 24 	spin_unlock_irqrestore(&wq_head->lock, flags);  in add_wait_queue()
 32 	wq_entry->flags |= WQ_FLAG_EXCLUSIVE;  in add_wait_queue_exclusive()
 33 	spin_lock_irqsave(&wq_head->lock, flags);  in add_wait_queue_exclusive()
 35 	spin_unlock_irqrestore(&wq_head->lock, flags);  in add_wait_queue_exclusive()
 [all …]
 
 | 
| /Linux-v6.6/drivers/gpu/drm/i915/display/ | 
| D | intel_display_rps.c | 1 // SPDX-License-Identifier: MIT15 	struct wait_queue_entry wait;  member
 24 	struct wait_rps_boost *wait = container_of(_wait, typeof(*wait), wait);  in do_rps_boost()  local
 25 	struct i915_request *rq = wait->request;  in do_rps_boost()
 36 	drm_crtc_vblank_put(wait->crtc);  in do_rps_boost()
 38 	list_del(&wait->wait.entry);  in do_rps_boost()
 39 	kfree(wait);  in do_rps_boost()
 46 	struct wait_rps_boost *wait;  in intel_display_rps_boost_after_vblank()  local
 51 	if (DISPLAY_VER(to_i915(crtc->dev)) < 6)  in intel_display_rps_boost_after_vblank()
 57 	wait = kmalloc(sizeof(*wait), GFP_KERNEL);  in intel_display_rps_boost_after_vblank()
 [all …]
 
 | 
| D | hsw_ips.c | 1 // SPDX-License-Identifier: MIT15 	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);  in hsw_ips_enable()
 16 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);  in hsw_ips_enable()
 19 	if (!crtc_state->ips_enabled)  in hsw_ips_enable()
 23 	 * We can only enable IPS after we enable a plane and wait for a vblank  in hsw_ips_enable()
 25 	 * a vblank wait.  in hsw_ips_enable()
 27 	drm_WARN_ON(&i915->drm,  in hsw_ips_enable()
 28 		    !(crtc_state->active_planes & ~BIT(PLANE_CURSOR)));  in hsw_ips_enable()
 32 	if (i915->display.ips.false_color)  in hsw_ips_enable()
 36 		drm_WARN_ON(&i915->drm,  in hsw_ips_enable()
 [all …]
 
 | 
| /Linux-v6.6/include/linux/ | 
| D | wait.h | 1 /* SPDX-License-Identifier: GPL-2.0 */5  * Linux wait queue related types and methods
 12 #include <uapi/linux/wait.h>
 28  * A single wait-queue entry structure:
 84 	wq_entry->flags		= 0;  in init_waitqueue_entry()
 85 	wq_entry->private	= p;  in init_waitqueue_entry()
 86 	wq_entry->func		= default_wake_function;  in init_waitqueue_entry()
 92 	wq_entry->flags		= 0;  in init_waitqueue_func_entry()
 93 	wq_entry->private	= NULL;  in init_waitqueue_func_entry()
 94 	wq_entry->func		= func;  in init_waitqueue_func_entry()
 [all …]
 
 | 
| D | swait.h | 1 /* SPDX-License-Identifier: GPL-2.0 */8 #include <linux/wait.h>
 12  * Simple waitqueues are semantically very different to regular wait queues
 13  * (wait.h). The most important difference is that the simple waitqueue allows
 14  * for deterministic behaviour -- IOW it has strictly bounded IRQ and lock hold
 24  *  - mixing INTERRUPTIBLE and UNINTERRUPTIBLE sleeps on the same waitqueue;
 26  *    sleeper state.
 28  *  - the !exclusive mode; because that leads to O(n) wakeups, everything is
 31  *  - custom wake callback functions; because you cannot give any guarantees
 35  * As a side effect of these; the data structures are slimmer albeit more ad-hoc.
 [all …]
 
 | 
| D | wait_bit.h | 1 /* SPDX-License-Identifier: GPL-2.0 */6  * Linux wait-bit related types and methods:
 8 #include <linux/wait.h>
 55  * wait_on_bit - wait for a bit to be cleared
 58  * @mode: the task state to sleep in
 66  * Returned value will be zero if the bit was cleared, or non-zero
 82  * wait_on_bit_io - wait for a bit to be cleared
 85  * @mode: the task state to sleep in
 87  * Use the standard hashed waitqueue table to wait for a bit
 91  * Returned value will be zero if the bit was cleared, or non-zero
 [all …]
 
 | 
| /Linux-v6.6/drivers/mtd/chips/ | 
| D | cfi_cmdset_0020.c | 1 // SPDX-License-Identifier: GPL-2.09  * 	- completely revamped method functions so they are aware and
 11  * 	- scalability vs code size is completely set at compile-time
 13  *	- optimized write buffer method
 14  * 06/21/2002	Joern Engel <joern@wh.fh-wedel.de> and others
 15  *	- modified Intel Command Set 0x0001 to support ST Advanced Architecture
 17  *	- added a writev function
 18  * 07/13/2005	Joern Engel <joern@wh.fh-wedel.de>
 19  * 	- Plugged memory leak in cfi_staa_writev().
 69         printk("  Feature/Command Support: %4.4X\n", extp->FeatureSupport);  in cfi_tell_features()
 [all …]
 
 | 
| /Linux-v6.6/include/soc/qcom/ | 
| D | tcs.h | 1 /* SPDX-License-Identifier: GPL-2.0 */3  * Copyright (c) 2016-2019, The Linux Foundation. All rights reserved.
 12  * rpmh_state: state for the request
 14  * RPMH_SLEEP_STATE:       State of the resource when the processor subsystem
 17  * RPMH_WAKE_ONLY_STATE:   Resume resource state to the value previously
 19  * RPMH_ACTIVE_ONLY_STATE: Active or AMC mode requests. Resource state
 32  * @data: the resource state request
 33  * @wait: ensure that this command is complete before returning.
 34  *        Setting "wait" here only makes sense during rpmh_write_batch() for
 35  *        active-only transfers, this is because:
 [all …]
 
 | 
| /Linux-v6.6/drivers/scsi/isci/ | 
| D | phy.h | 7  * Copyright(c) 2008 - 2011 Intel Corporation. All rights reserved.20  * Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
 26  * Copyright(c) 2008 - 2011 Intel Corporation. All rights reserved.
 63 /* This is the timeout value for the SATA phy to wait for a SIGNATURE FIS
 64  * before restarting the starting state machine.  Technically, the old parallel
 74  * notification from the hardware that we restart the hardware OOB state
 80  * isci_phy - hba local phy infrastructure
 83  * @phy_index: physical index relative to the controller (0-3)
 162  * struct sci_phy_properties - This structure defines the properties common to
 189  * struct sci_sas_phy_properties - This structure defines the properties,
 [all …]
 
 | 
| /Linux-v6.6/drivers/net/ethernet/sfc/falcon/ | 
| D | selftest.c | 1 // SPDX-License-Identifier: GPL-2.0-only4  * Copyright 2005-2006 Fen Systems Ltd.
 5  * Copyright 2006-2012 Solarflare Communications Inc.
 26  * - All IRQs may be disabled on a CPU for a *long* time by e.g. a
 28  * - The PREEMPT_RT patches mostly deal with this, but also allow a
 38  * The self-test should stress every RSS vector, and unfortunately
 42 	char pad[2]; /* Ensures ip is 4-byte aligned */
 65 	[EF4_INT_MODE_MSIX]   = "MSI-X",
 70 	STRING_TABLE_LOOKUP(efx->interrupt_mode, ef4_interrupt_mode)
 73  * struct ef4_loopback_state - persistent state during a loopback selftest
 [all …]
 
 | 
| /Linux-v6.6/drivers/net/ethernet/sfc/siena/ | 
| D | selftest.c | 1 // SPDX-License-Identifier: GPL-2.0-only4  * Copyright 2005-2006 Fen Systems Ltd.
 5  * Copyright 2006-2012 Solarflare Communications Inc.
 29  * - All IRQs may be disabled on a CPU for a *long* time by e.g. a
 31  * - The PREEMPT_RT patches mostly deal with this, but also allow a
 41  * The self-test should stress every RSS vector, and unfortunately
 45 	char pad[2]; /* Ensures ip is 4-byte aligned */
 68 	[EFX_INT_MODE_MSIX]   = "MSI-X",
 73 	STRING_TABLE_LOOKUP(efx->interrupt_mode, efx_siena_interrupt_mode)
 76  * struct efx_loopback_state - persistent state during a loopback selftest
 [all …]
 
 | 
| /Linux-v6.6/drivers/infiniband/hw/hfi1/ | 
| D | vnic_sdma.c | 1 // SPDX-License-Identifier: GPL-2.0 or BSD-3-Clause3  * Copyright(c) 2017 - 2018 Intel Corporation.
 20  * struct vnic_txreq - VNIC transmit descriptor
 42 	struct hfi1_vnic_sdma *vnic_sdma = tx->sdma;  in vnic_sdma_complete()
 44 	sdma_txclean(vnic_sdma->dd, txreq);  in vnic_sdma_complete()
 45 	dev_kfree_skb_any(tx->skb);  in vnic_sdma_complete()
 46 	kmem_cache_free(vnic_sdma->dd->vnic.txreq_cache, tx);  in vnic_sdma_complete()
 55 		sde->dd,  in build_vnic_ulp_payload()
 56 		&tx->txreq,  in build_vnic_ulp_payload()
 57 		tx->skb->data,  in build_vnic_ulp_payload()
 [all …]
 
 | 
| /Linux-v6.6/drivers/soc/qcom/ | 
| D | trace-rpmh.h | 1 /* SPDX-License-Identifier: GPL-2.0 */3  * Copyright (c) 2016-2018, The Linux Foundation. All rights reserved.
 13 #include "rpmh-internal.h"
 22 			 __string(name, d->name)
 29 		       __assign_str(name, d->name);
 30 		       __entry->m = m;
 31 		       __entry->addr = r->cmds[0].addr;
 32 		       __entry->data = r->cmds[0].data;
 35 	TP_printk("%s: ack: tcs-m: %d addr: %#x data: %#x",
 36 		  __get_str(name), __entry->m, __entry->addr, __entry->data)
 [all …]
 
 | 
| /Linux-v6.6/drivers/net/ethernet/sfc/ | 
| D | selftest.c | 1 // SPDX-License-Identifier: GPL-2.0-only4  * Copyright 2005-2006 Fen Systems Ltd.
 5  * Copyright 2006-2012 Solarflare Communications Inc.
 29  * - All IRQs may be disabled on a CPU for a *long* time by e.g. a
 31  * - The PREEMPT_RT patches mostly deal with this, but also allow a
 41  * The self-test should stress every RSS vector.
 44 	char pad[2]; /* Ensures ip is 4-byte aligned */
 67 	[EFX_INT_MODE_MSIX]   = "MSI-X",
 72 	STRING_TABLE_LOOKUP(efx->interrupt_mode, efx_interrupt_mode)
 75  * struct efx_loopback_state - persistent state during a loopback selftest
 [all …]
 
 | 
| /Linux-v6.6/arch/powerpc/platforms/powernv/ | 
| D | opal-async.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later5  * Copyright 2013-2017 IBM Corp.
 16 #include <linux/wait.h>
 31 	enum opal_async_token_state state;  member
 44 	int i, token = -EBUSY;  in __opal_async_get_token()
 49 		if (opal_async_tokens[i].state == ASYNC_TOKEN_UNALLOCATED) {  in __opal_async_get_token()
 50 			opal_async_tokens[i].state = ASYNC_TOKEN_ALLOCATED;  in __opal_async_get_token()
 70 	/* Wait until a token is available */  in opal_async_get_token_interruptible()
 72 		return -ERESTARTSYS;  in opal_async_get_token_interruptible()
 90 		return -EINVAL;  in __opal_async_release_token()
 [all …]
 
 | 
| /Linux-v6.6/kernel/locking/ | 
| D | qspinlock_paravirt.h | 1 /* SPDX-License-Identifier: GPL-2.0 */16  *   pv_wait(u8 *ptr, u8 val) -- suspends the vcpu if *ptr == val
 17  *   pv_kick(cpu)             -- wakes a suspended vcpu
 31  * mitigates the slight slowdown for non-overcommitted guest with this
 32  * aggressive wait-early mechanism.
 53 	u8			state;  member
 63  * The pending bit is set by the queue head vCPU of the MCS wait queue in
 67  * enter the MCS wait queue. So lock starvation shouldn't happen as long
 72  * mode spinning on the lock unless the MCS wait queue is empty. In this
 85 	 * present in the MCS wait queue but the pending bit isn't set.  in pv_hybrid_queued_unfair_trylock()
 [all …]
 
 | 
| /Linux-v6.6/drivers/net/wwan/iosm/ | 
| D | iosm_ipc_pm.h | 1 /* SPDX-License-Identifier: GPL-2.0-only3  * Copyright (C) 2020-21 Intel Corporation.
 18  * union ipc_pm_cond - Conditions for D3 and the sleep message to CP.
 22  * @link:	Device link state.
 35  * enum ipc_mem_host_pm_state - Possible states of the HOST SLEEP finite state
 38  * @IPC_MEM_HOST_PM_ACTIVE_WAIT:	   Intermediate state before going to
 40  * @IPC_MEM_HOST_PM_SLEEP_WAIT_IDLE:	   Intermediate state to wait for idle
 42  * @IPC_MEM_HOST_PM_SLEEP_WAIT_D3:	   Intermediate state to wait for D3
 44  * @IPC_MEM_HOST_PM_SLEEP:		   after this state the interface is not
 46  * @IPC_MEM_HOST_PM_SLEEP_WAIT_EXIT_SLEEP: Intermediate state before exiting
 [all …]
 
 | 
| D | iosm_ipc_imem_ops.c | 1 // SPDX-License-Identifier: GPL-2.0-only3  * Copyright (C) 2020-21 Intel Corporation.
 18 	dev_dbg(ipc_imem->dev, "%s if id: %d",  in ipc_imem_sys_wwan_open()
 19 		ipc_imem_phase_get_string(ipc_imem->phase), if_id);  in ipc_imem_sys_wwan_open()
 23 		dev_err(ipc_imem->dev, "net:%d : refused phase %s", if_id,  in ipc_imem_sys_wwan_open()
 24 			ipc_imem_phase_get_string(ipc_imem->phase));  in ipc_imem_sys_wwan_open()
 25 		return -EIO;  in ipc_imem_sys_wwan_open()
 28 	return ipc_mux_open_session(ipc_imem->mux, if_id);  in ipc_imem_sys_wwan_open()
 35 	if (ipc_imem->mux && if_id >= IP_MUX_SESSION_START &&  in ipc_imem_sys_wwan_close()
 37 		ipc_mux_close_session(ipc_imem->mux, if_id);  in ipc_imem_sys_wwan_close()
 [all …]
 
 | 
| /Linux-v6.6/drivers/gpu/drm/renesas/rcar-du/ | 
| D | rcar_du_crtc.h | 1 /* SPDX-License-Identifier: GPL-2.0+ */3  * R-Car Display Unit CRTCs
 5  * Copyright (C) 2013-2015 Renesas Electronics Corporation
 15 #include <linux/wait.h>
 26  * struct rcar_du_crtc - the CRTC, representing a DU superposition processor
 37  * @flip_wait: wait queue used to signal page flip completion
 39  * @vblank_wait: wait queue used to signal vertical blanking
 40  * @vblank_count: number of vertical blanking interrupts to wait for
 82  * struct rcar_du_crtc_state - Driver-specific CRTC state
 83  * @state: base DRM CRTC state
 [all …]
 
 | 
| /Linux-v6.6/Documentation/devicetree/bindings/arm/msm/ | 
| D | qcom,idle-state.txt | 3 ARM provides idle-state node to define the cpuidle states, as defined in [1].4 cpuidle-qcom is the cpuidle driver for Qualcomm SoCs and uses these idle
 6 The idle states supported by the QCOM SoC are defined as -
 16 trigger to execute the SPM state machine. The SPM state machine waits for the
 19 the SPM state machine out of its wait, the next step is to ensure that the
 21 execution. This state is defined as a generic ARM WFI state by the ARM cpuidle
 22 driver and is not defined in the DT. The SPM state machine should be
 23 configured to execute this state by default and after executing every other
 24 state below.
 26 Retention: Retention is a low power state where the core is clock gated and
 [all …]
 
 | 
| /Linux-v6.6/drivers/gpu/drm/amd/display/dmub/ | 
| D | dmub_srv.h | 36  * This interface is not thread-safe. Ensure that all access to the interface58  * wait until the queue has been cleared.
 61  * This does not clear DMUB hardware state, only software state.
 80 /* enum dmub_status - return code for dmcub functions */
 90 /* enum dmub_asic - dmub asic identifier */
 109 /* enum dmub_window_id - dmub window identifier */
 122 /* enum dmub_notification_type - dmub outbox notification identifier */
 145  * struct dmub_region - dmub hw memory region
 155  * struct dmub_window - dmub hw cache window
 165  * struct dmub_fb - defines a dmub framebuffer memory region
 [all …]
 
 | 
| /Linux-v6.6/drivers/staging/media/omap4iss/ | 
| D | iss_ipipe.h | 1 /* SPDX-License-Identifier: GPL-2.0+ */3  * TI OMAP4 ISS V4L2 Driver - ISP IPIPE module
 28  * struct iss_ipipe_device - Structure for the IPIPE module to store its own
 36  * @state: Streaming state
 37  * @wait: Wait queue used to stop the module
 38  * @stopping: Stopping state
 49 	enum iss_pipeline_stream_state state;  member
 50 	wait_queue_head_t wait;  member
 
 | 
| /Linux-v6.6/drivers/net/wireless/mediatek/mt76/mt7921/ | 
| D | sdio_mac.c | 1 // SPDX-License-Identifier: ISC12 	struct mt76_sdio *sdio = &dev->sdio;  in mt7921s_enable_irq()
 14 	sdio_claim_host(sdio->func);  in mt7921s_enable_irq()
 15 	sdio_writel(sdio->func, WHLPCR_INT_EN_SET, MCR_WHLPCR, NULL);  in mt7921s_enable_irq()
 16 	sdio_release_host(sdio->func);  in mt7921s_enable_irq()
 21 	struct mt76_sdio *sdio = &dev->sdio;  in mt7921s_disable_irq()
 23 	sdio_claim_host(sdio->func);  in mt7921s_disable_irq()
 24 	sdio_writel(sdio->func, WHLPCR_INT_EN_CLR, MCR_WHLPCR, NULL);  in mt7921s_disable_irq()
 25 	sdio_release_host(sdio->func);  in mt7921s_disable_irq()
 30 	return sdio_readl(dev->sdio.func, MCR_WHCR, NULL);  in mt7921s_read_whcr()
 [all …]
 
 |