Home
last modified time | relevance | path

Searched +full:wait +full:- +full:free +full:- +full:us (Results 1 – 25 of 1008) sorted by relevance

12345678910>>...41

/linux/Documentation/devicetree/bindings/i2c/
H A Di2c-arb-gpio-challenge.yaml1 # SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
3 ---
4 $id: http://devicetree.org/schemas/i2c/i2c-arb-gpio-challenge.yaml#
5 $schema: http://devicetree.org/meta-schemas/core.yaml#
7 title: GPIO-based I2C Arbitration Using a Challenge & Response Mechanism
10 - Doug Anderson <dianders@chromium.org>
11 - Peter Rosin <peda@axentia.se>
18 standard I2C multi-master rules. Using GPIOs is generally useful in the case
30 others can see. These are all active low with pull-ups enabled. We'll
32 * OUR_CLAIM: output from us signaling to other hosts that we want the bus
[all …]
/linux/drivers/gpu/drm/nouveau/
H A Dnouveau_dma.c5 * Permission is hereby granted, free of charge, to any person obtaining
37 * -EINVAL if GET pointer currently outside main push buffer
38 * -EBUSY if timeout exceeded
45 val = nvif_rd32(chan->userd, chan->user_get); in READ_GET()
46 if (chan->user_get_hi) in READ_GET()
47 val |= (uint64_t)nvif_rd32(chan->userd, chan->user_get_hi) << 32; in READ_GET()
61 return -EBUSY; in READ_GET()
64 if (val < chan->push.addr || in READ_GET()
65 val > chan->push.addr + (chan->dma.max << 2)) in READ_GET()
66 return -EINVAL; in READ_GET()
[all …]
/linux/fs/btrfs/
H A Dspace-info.c1 // SPDX-License-Identifier: GPL-2.0
7 #include "space-info.h"
10 #include "free-space-cache.h"
11 #include "ordered-data.h"
13 #include "block-group.h"
16 #include "extent-tree.h"
30 * reservations we care about total_bytes - SUM(space_info->bytes_) when
36 * code on the rules for each type, but generally block_rsv->reserved is how
37 * much space is accounted for in space_info->bytes_may_use.
51 * ->reserve
[all …]
/linux/arch/arm/mach-omap1/
H A Dsleep.S2 * linux/arch/arm/mach-omap1/sleep.S
4 * Low-level OMAP7XX/1510/1610 sleep/wakeUp support
14 * This program is free software; you can redistribute it and/or modify it
16 * Free Software Foundation; either version 2 of the License, or (at your
31 * with this program; if not, write to the Free Software Foundation, Inc.,
69 stmfd sp!, {r0 - r12, lr}
86 @ prepare to put SDRAM into self-refresh manually
118 * Let's wait for the next wake up event to wake us up. r0 can't be
122 mcr p15, 0, r2, c7, c0, 4 @ wait for interrupt
133 ldmfd sp!, {r0 - r12, pc}
[all …]
/linux/drivers/rtc/
H A Drtc-tegra.c1 // SPDX-License-Identifier: GPL-2.0+
5 * Copyright (c) 2010-2019, NVIDIA Corporation.
59 * eight 32 kHz clocks (~250 us). Outside of these updates the CPU is free to
60 * write. CPU is always free to read.
64 return readl(info->base + TEGRA_RTC_REG_BUSY) & 1; in tegra_rtc_check_busy()
68 * Wait for hardware to be ready for writing. This function tries to maximize
74 * AHB side) occurs every eight 32 kHz clocks (~250 us). The behavior of this
75 * function allows us to make some assumptions without introducing a race,
76 * because 250 us is plenty of time to read/write a value.
81 int retries = 500; /* ~490 us is the worst case, ~250 us is best */ in tegra_rtc_wait_while_busy()
[all …]
/linux/drivers/scsi/aic7xxx/
H A Daic79xx.seq4 * Copyright (c) 1994-2001, 2004 Justin T. Gibbs.
5 * Copyright (c) 2000-2002 Adaptec Inc.
19 * 3. Neither the names of the above-listed copyright holders nor the names
24 * GNU General Public License ("GPL") version 2 as published by the Free
51 if ((ahd->bugs & AHD_INTCOLLISION_BUG) != 0) {
58 if ((ahd->bugs & AHD_INTCOLLISION_BUG) != 0) {
73 * If the kernel has caught up with us, thaw the queue.
100 cmp SCB_NEXT_COMPLETE[1], SCB_LIST_NULL jne . - 1;
124 if ((ahd->bugs & AHD_FAINT_LED_BUG) != 0) {
128 * and re-selections. Make the LED status
[all …]
H A Daic7xxx.seq4 * Copyright (c) 1994-2001 Justin T. Gibbs.
5 * Copyright (c) 2000-2001 Adaptec Inc.
19 * 3. Neither the names of the above-listed copyright holders nor the names
24 * GNU General Public License ("GPL") version 2 as published by the Free
60 * use byte 27 of the SCB as a pseudo-next pointer and to thread a list
61 * of SCBs that are awaiting selection. Since 0-0xfe are valid SCB indexes,
63 * this list every time a request sense occurs or after completing a non-tagged
78 if ((ahc->features & AHC_ULTRA2) != 0) {
82 if ((ahc->features & AHC_TWIN) != 0) {
88 if ((ahc->features & AHC_TWIN) != 0) {
[all …]
/linux/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn32/
H A Ddcn32_clk_mgr_smu_msg.c4 * Permission is hereby granted, free of charge, to any person obtaining a
46 * Function to be used instead of REG_WAIT macro because the wait ends when
64 } while (max_retries--); in dcn32_smu_wait_for_response()
66 TRACE_SMU_DELAY(delay_us * (initial_max_retries - max_retries), clk_mgr->base.ctx); in dcn32_smu_wait_for_response()
73 /* Wait for response register to be ready */ in dcn32_smu_send_msg_with_param()
85 TRACE_SMU_MSG(msg_id, param_in, clk_mgr->base.ctx); in dcn32_smu_send_msg_with_param()
87 /* Wait for response */ in dcn32_smu_send_msg_with_param()
121 } while (max_retries--); in dcn32_smu_wait_for_response_delay()
123 TRACE_SMU_DELAY(*total_delay_us, clk_mgr->base.ctx); in dcn32_smu_wait_for_response_delay()
133 /* Wait for response register to be ready */ in dcn32_smu_send_msg_with_param_delay()
[all …]
/linux/kernel/locking/
H A Dqspinlock_paravirt.h1 /* 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.
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()
88 int val = atomic_read(&lock->val); in pv_hybrid_queued_unfair_trylock()
[all …]
/linux/drivers/usb/storage/
H A Dusb.c1 // SPDX-License-Identifier: GPL-2.0+
6 * (c) 1999-2003 Matthew Dharm (mdharm-usb@one-eyed-alien.net)
9 * (c) 2000 David L. Brown, Jr. (usb-storage@davidb.org)
10 * (c) 2003-2009 Alan Stern (stern@rowland.harvard.edu)
22 * similar to commands in the SCSI-II and ATAPI specifications.
25 * exhibits class-specific exemptions from the USB specification.
27 * that they are used to communicate wait, failed and OK on commands.
61 #include "uas-detect.h"
64 #define DRV_NAME "usb-storage"
67 MODULE_AUTHOR("Matthew Dharm <mdharm-usb@one-eyed-alien.net>");
[all …]
/linux/drivers/net/ethernet/marvell/
H A Dmvmdio.c13 * Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
34 #include <linux/wait.h>
65 * - Kirkwood 88F6281 (Globalscale Dreamplug): 45us to 95us (Interrupt)
66 * - Armada 370 (Globalscale Mirabox): 41us to 43us (Polled)
68 #define MVMDIO_SMI_TIMEOUT 1000 /* 1000us = 1ms */
76 * but also reflects SMI completion), use that to wait for
92 /* Wait for the SMI unit to be ready for another operation
97 struct orion_mdio_dev *dev = bus->priv; in orion_mdio_wait_ready()
101 if (dev->err_interrupt <= 0) { in orion_mdio_wait_ready()
102 if (!read_poll_timeout_atomic(ops->is_done, done, done, 2, in orion_mdio_wait_ready()
[all …]
/linux/fs/xfs/
H A Dxfs_icache.c1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (c) 2000-2005 Silicon Graphics, Inc.
97 ip = alloc_inode_sb(mp->m_super, xfs_inode_cache, GFP_KERNEL | __GFP_NOFAIL); in xfs_inode_alloc()
99 if (inode_init_always(mp->m_super, VFS_I(ip))) { in xfs_inode_alloc()
105 VFS_I(ip)->i_mode = 0; in xfs_inode_alloc()
106 mapping_set_folio_min_order(VFS_I(ip)->i_mapping, in xfs_inode_alloc()
107 M_IGEO(mp)->min_folio_order); in xfs_inode_alloc()
110 ASSERT(atomic_read(&ip->i_pincount) == 0); in xfs_inode_alloc()
111 ASSERT(ip->i_ino == 0); in xfs_inode_alloc()
114 ip->i_ino = ino; in xfs_inode_alloc()
[all …]
H A Dxfs_trans_ail.c1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
36 __must_hold(&ailp->ail_lock) in xfs_ail_check()
46 if (list_empty(&ailp->ail_head)) in xfs_ail_check()
52 in_ail = test_bit(XFS_LI_IN_AIL, &lip->li_flags); in xfs_ail_check()
53 prev_lip = list_entry(lip->li_ail.prev, struct xfs_log_item, li_ail); in xfs_ail_check()
54 if (&prev_lip->li_ail != &ailp->ail_head) in xfs_ail_check()
55 prev_lsn = prev_lip->li_lsn; in xfs_ail_check()
56 next_lip = list_entry(lip->li_ail.next, struct xfs_log_item, li_ail); in xfs_ail_check()
57 if (&next_lip->li_ail != &ailp->ail_head) in xfs_ail_check()
[all …]
/linux/Documentation/RCU/
H A DRTFP.txt4 This document describes RCU-related publications, and is followed by
19 with short-lived threads, such as the K42 research operating system.
20 However, Linux has long-lived tasks, so more is needed.
23 serialization, which is an RCU-like mechanism that relies on the presence
27 that these overheads were not so expensive in the mid-80s. Nonetheless,
28 passive serialization appears to be the first deferred-destruction
30 has lapsed, so this approach may be used in non-GPL software, if desired.
34 In 1987, Rashid et al. described lazy TLB-flush [RichardRashid87a].
36 this paper helped inspire the update-side batching used in the later
38 a description of Argus that noted that use of out-of-date values can
[all …]
/linux/drivers/gpu/drm/i915/
H A Di915_utils.h4 * Permission is hereby granted, free of charge, to any person obtaining a
43 #define FDO_BUG_URL "https://drm.pages.freedesktop.org/intel-docs/how-to-file-i915-bugs.html"
63 #define i915_inject_probe_failure(i915) i915_inject_probe_error((i915), -ENODEV)
67 drm_dbg(&(i915)->drm, fmt, ##__VA_ARGS__); \
69 drm_err(&(i915)->drm, fmt, ##__VA_ARGS__); \
78 start__ >= max__ || size__ > max__ - start__; \
90 start__ > max__ || size__ > max__ - start__; \
98 (typeof(ptr))(__v & -BIT(n)); \
101 #define ptr_unmask_bits(ptr, n) ((unsigned long)(ptr) & (BIT(n) - 1))
105 *(bits) = __v & (BIT(n) - 1); \
[all …]
/linux/kernel/
H A Dexit.c1 // SPDX-License-Identifier: GPL-2.0-only
43 #include <linux/posix-timers.h>
73 #include <uapi/linux/wait.h>
83 * overflowing 32-bit refcounts or the ldsem writer count.
127 nr_threads--; in __unhash_process()
134 list_del_rcu(&p->tasks); in __unhash_process()
135 list_del_init(&p->sibling); in __unhash_process()
138 list_del_rcu(&p->thread_node); in __unhash_process()
142 * This function expects the tasklist_lock write-locked.
146 struct signal_struct *sig = tsk->signal; in __exit_signal()
[all …]
/linux/Documentation/filesystems/xfs/
H A Dxfs-delayed-logging-design.rst1 .. SPDX-License-Identifier: GPL-2.0
33 details logged are made up of the changes to in-core structures rather than
34 on-disk structures. Other objects - typically buffers - have their physical
64 place. This means that permanent transactions can be used for one-shot
65 modifications, but one-shot reservations cannot be used for permanent
68 In the code, a one-shot transaction pattern looks somewhat like this::
97 While this might look similar to a one-shot transaction, there is an important
123 the on-disk journal.
142 in the journal and wait for that to complete.
165 transaction, we have to reserve enough space to record a full leaf-to-root split
[all …]
/linux/tools/testing/selftests/timers/
H A Dskew_consistency.c2 * by: john stultz (johnstul@us.ibm.com)
6 * NOTE: This is a meta-test which cranks the ADJ_FREQ knob back
8 * that the inconsistency-check tests be present in the same directory it
12 * $ gcc skew_consistency.c -o skew_consistency -lrt
14 * This program is free software: you can redistribute it and/or modify
16 * the Free Software Foundation, either version 2 of the License, or
36 #include <sys/wait.h>
50 return system("./inconsistency-check -c 1 -t 600"); in main()
56 ppm = -ppm; in main()
/linux/arch/arm/boot/dts/allwinner/
H A Dsun7i-a20-hummingbird.dts6 * This file is dual-licensed: you can use it either under the terms
11 * a) This file is free software; you can redistribute it and/or
13 * published by the Free Software Foundation; either version 2 of the
23 * b) Permission is hereby granted, free of charge, to any person
45 /dts-v1/;
46 #include "sun7i-a20.dtsi"
47 #include "sunxi-common-regulators.dtsi"
49 #include <dt-bindings/gpio/gpio.h>
50 #include <dt-bindings/interrupt-controller/irq.h>
54 compatible = "merrii,a20-hummingbird", "allwinner,sun7i-a20";
[all …]
/linux/drivers/gpu/drm/scheduler/
H A Dsched_fence.c4 * Permission is hereby granted, free of charge, to any person obtaining a
28 #include <linux/wait.h>
38 return -ENOMEM; in drm_sched_fence_slab_init()
53 * smp_store_release() to ensure another thread racing us in drm_sched_fence_set_parent()
57 smp_store_release(&s_fence->parent, dma_fence_get(fence)); in drm_sched_fence_set_parent()
59 &s_fence->finished.flags)) in drm_sched_fence_set_parent()
60 dma_fence_set_deadline(fence, s_fence->deadline); in drm_sched_fence_set_parent()
69 * to some firmware) doesn't have to busy wait for parent to show in drm_sched_fence_scheduled()
75 dma_fence_signal(&fence->scheduled); in drm_sched_fence_scheduled()
81 dma_fence_set_error(&fence->finished, result); in drm_sched_fence_finished()
[all …]
/linux/drivers/gpu/drm/amd/amdgpu/
H A Damdgpu_cs.c5 * Permission is hereby granted, free of charge, to any person obtaining a
31 #include <linux/dma-buf.h>
49 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_cs_parser_init()
51 if (cs->in.num_chunks == 0) in amdgpu_cs_parser_init()
52 return -EINVAL; in amdgpu_cs_parser_init()
55 p->adev = adev; in amdgpu_cs_parser_init()
56 p->filp = filp; in amdgpu_cs_parser_init()
58 p->ctx = amdgpu_ctx_get(fpriv, cs->in.ctx_id); in amdgpu_cs_parser_init()
59 if (!p->ctx) in amdgpu_cs_parser_init()
60 return -EINVAL; in amdgpu_cs_parser_init()
[all …]
/linux/fs/
H A Deventpoll.c1 // SPDX-License-Identifier: GPL-2.0-or-later
25 #include <linux/wait.h>
48 * 2) ep->mtx (mutex)
49 * 3) ep->lock (rwlock)
52 * We need a rwlock (ep->lock) because we manipulate objects
58 * we need a lock that will allow us to sleep. This lock is a
59 * mutex (ep->mtx). It is acquired during the event transfer loop,
68 * It is necessary to acquire multiple "ep->mtx"es at once in the
71 * epoll_ctl(e1, EPOLL_CTL_ADD, e2), e1->mtx will always be acquired
72 * before e2->mtx). Since we disallow cycles of epoll file
[all …]
/linux/io_uring/
H A Dpoll.c1 // SPDX-License-Identifier: GPL-2.0
49 * We usually have 1-2 refs taken, 128 is more than enough and we want to
56 static int io_poll_wake(struct wait_queue_entry *wait, unsigned mode, int sync,
61 unsigned long priv = (unsigned long)wqe->private; in wqe_to_req()
68 unsigned long priv = (unsigned long)wqe->private; in wqe_is_double()
82 v = atomic_fetch_or(IO_POLL_RETRY_FLAG, &req->poll_refs); in io_poll_get_ownership_slowpath()
85 return !(atomic_fetch_inc(&req->poll_refs) & IO_POLL_REF_MASK); in io_poll_get_ownership_slowpath()
89 * If refs part of ->poll_refs (see IO_POLL_REF_MASK) is 0, it's free. We can
96 if (unlikely(atomic_read(&req->poll_refs) >= IO_POLL_REF_BIAS)) in io_poll_get_ownership()
98 return !(atomic_fetch_inc(&req->poll_refs) & IO_POLL_REF_MASK); in io_poll_get_ownership()
[all …]
H A Dio-wq.c1 // SPDX-License-Identifier: GPL-2.0
22 #include "io-wq.h"
32 IO_WORKER_F_FREE = 2, /* worker on free list */
121 struct wait_queue_entry wait; member
148 return refcount_inc_not_zero(&worker->ref); in io_worker_get()
153 if (refcount_dec_and_test(&worker->ref)) in io_worker_release()
154 complete(&worker->ref_done); in io_worker_release()
159 return &wq->acct[bound ? IO_WQ_ACCT_BOUND : IO_WQ_ACCT_UNBOUND]; in io_get_acct()
165 return io_get_acct(wq, !(atomic_read(&work->flags) & IO_WQ_WORK_UNBOUND)); in io_work_get_acct()
170 return io_get_acct(worker->wq, test_bit(IO_WORKER_F_BOUND, &worker->flags)); in io_wq_get_acct()
[all …]
/linux/drivers/md/bcache/
H A Djournal.h1 /* SPDX-License-Identifier: GPL-2.0 */
8 * The journal is treated as a circular buffer of buckets - a journal entry
16 * superblock - all the things that are frequently updated. This is for future
22 * Currently, we don't journal BTREE_REPLACE operations - this will hopefully be
23 * fixed eventually. This isn't a bug - BTREE_REPLACE is used for insertions
32 * journal entry still open - i.e. that has keys that haven't been flushed to
38 * zero, we pop it off - thus, the size of the fifo tells us the number of open
48 * might contain keys for many journal entries - we handle this by making sure
54 * As mentioned previously, our fifo of refcounts tells us the number of open
56 * last_seq - the oldest journal entry we still need. We write last_seq in each
[all …]

12345678910>>...41