Home
last modified time | relevance | path

Searched refs:semaphore (Results 1 – 25 of 168) sorted by relevance

1234567

/linux-6.12.1/drivers/gpu/drm/radeon/
Dradeon_semaphore.c35 struct radeon_semaphore **semaphore) in radeon_semaphore_create() argument
39 *semaphore = kmalloc(sizeof(struct radeon_semaphore), GFP_KERNEL); in radeon_semaphore_create()
40 if (*semaphore == NULL) { in radeon_semaphore_create()
44 &(*semaphore)->sa_bo, 8, 8); in radeon_semaphore_create()
46 kfree(*semaphore); in radeon_semaphore_create()
47 *semaphore = NULL; in radeon_semaphore_create()
50 (*semaphore)->waiters = 0; in radeon_semaphore_create()
51 (*semaphore)->gpu_addr = radeon_sa_bo_gpu_addr((*semaphore)->sa_bo); in radeon_semaphore_create()
53 *((uint64_t *)radeon_sa_bo_cpu_addr((*semaphore)->sa_bo)) = 0; in radeon_semaphore_create()
59 struct radeon_semaphore *semaphore) in radeon_semaphore_emit_signal() argument
[all …]
Dradeon_test.c318 struct radeon_semaphore *semaphore = NULL; in radeon_test_ring_sync() local
321 r = radeon_semaphore_create(rdev, &semaphore); in radeon_test_ring_sync()
332 radeon_semaphore_emit_wait(rdev, ringA->idx, semaphore); in radeon_test_ring_sync()
344 radeon_semaphore_emit_wait(rdev, ringA->idx, semaphore); in radeon_test_ring_sync()
363 radeon_semaphore_emit_signal(rdev, ringB->idx, semaphore); in radeon_test_ring_sync()
384 radeon_semaphore_emit_signal(rdev, ringB->idx, semaphore); in radeon_test_ring_sync()
394 radeon_semaphore_free(rdev, &semaphore, NULL); in radeon_test_ring_sync()
412 struct radeon_semaphore *semaphore = NULL; in radeon_test_ring_sync2() local
416 r = radeon_semaphore_create(rdev, &semaphore); in radeon_test_ring_sync2()
427 radeon_semaphore_emit_wait(rdev, ringA->idx, semaphore); in radeon_test_ring_sync2()
[all …]
Dradeon_sync.c130 struct radeon_semaphore *semaphore; in radeon_sync_rings() local
149 r = radeon_semaphore_create(rdev, &semaphore); in radeon_sync_rings()
153 sync->semaphores[count++] = semaphore; in radeon_sync_rings()
161 if (!radeon_semaphore_emit_signal(rdev, i, semaphore)) { in radeon_sync_rings()
171 if (!radeon_semaphore_emit_wait(rdev, ring, semaphore)) { in radeon_sync_rings()
Duvd_v3_1.c41 struct radeon_semaphore *semaphore, in uvd_v3_1_semaphore_emit() argument
44 uint64_t addr = semaphore->gpu_addr; in uvd_v3_1_semaphore_emit()
Duvd_v2_2.c74 struct radeon_semaphore *semaphore, in uvd_v2_2_semaphore_emit() argument
77 uint64_t addr = semaphore->gpu_addr; in uvd_v2_2_semaphore_emit()
/linux-6.12.1/kernel/locking/
Dsemaphore.c37 static noinline void __down(struct semaphore *sem);
38 static noinline int __down_interruptible(struct semaphore *sem);
39 static noinline int __down_killable(struct semaphore *sem);
40 static noinline int __down_timeout(struct semaphore *sem, long timeout);
41 static noinline void __up(struct semaphore *sem);
54 void __sched down(struct semaphore *sem) in down()
77 int __sched down_interruptible(struct semaphore *sem) in down_interruptible()
104 int __sched down_killable(struct semaphore *sem) in down_killable()
134 int __sched down_trylock(struct semaphore *sem) in down_trylock()
159 int __sched down_timeout(struct semaphore *sem, long timeout) in down_timeout()
[all …]
/linux-6.12.1/include/linux/
Dsemaphore.h15 struct semaphore { struct
35 struct semaphore _name = __SEMAPHORE_INITIALIZER(_name, _n) argument
37 static inline void sema_init(struct semaphore *sem, int val) in sema_init()
40 *sem = (struct semaphore) __SEMAPHORE_INITIALIZER(*sem, val); in sema_init()
44 extern void down(struct semaphore *sem);
45 extern int __must_check down_interruptible(struct semaphore *sem);
46 extern int __must_check down_killable(struct semaphore *sem);
47 extern int __must_check down_trylock(struct semaphore *sem);
48 extern int __must_check down_timeout(struct semaphore *sem, long jiffies);
49 extern void up(struct semaphore *sem);
Dhil_mlc.h136 struct semaphore csem; /* Raised when loop idle */
139 struct semaphore osem; /* Raised when outpacket dispatched */
143 struct semaphore isem; /* Raised when a packet arrives */
Dhp_sdc.h71 struct semaphore *semaphore; /* Semaphore to sleep on. */ member
/linux-6.12.1/include/drm/
Dtask_barrier.h42 struct semaphore enter_turnstile;
43 struct semaphore exit_turnstile;
46 static inline void task_barrier_signal_turnstile(struct semaphore *turnstile, in task_barrier_signal_turnstile()
/linux-6.12.1/drivers/input/serio/
Dhp_sdc_mlc.c193 if (priv->trans.act.semaphore != &mlc->csem) in hp_sdc_mlc_cts()
203 priv->trans.act.semaphore = &mlc->csem; in hp_sdc_mlc_cts()
217 priv->trans.act.semaphore = &mlc->osem; in hp_sdc_mlc_cts()
245 priv->trans.act.semaphore = &mlc->osem; in hp_sdc_mlc_out()
286 priv->trans.act.semaphore = &mlc->osem; in hp_sdc_mlc_out()
316 hp_sdc_mlc_priv.trans.act.semaphore = &mlc->osem; in hp_sdc_mlc_init()
Dhp_sdc.c201 if (curr->act.semaphore) in hp_sdc_take()
202 up(curr->act.semaphore); in hp_sdc_take()
328 if (curr->act.semaphore) in hp_sdc_tasklet()
329 up(curr->act.semaphore); in hp_sdc_tasklet()
566 up(curr->act.semaphore); in hp_sdc_put()
833 struct semaphore s_sync; in hp_sdc_init()
903 t_sync.act.semaphore = &s_sync; in hp_sdc_init()
998 struct semaphore tq_init_sem; in hp_sdc_register()
1039 tq_init.act.semaphore = &tq_init_sem; in hp_sdc_register()
/linux-6.12.1/drivers/acpi/acpica/
Dexsystem.c31 acpi_status acpi_ex_system_wait_semaphore(acpi_semaphore semaphore, u16 timeout) in acpi_ex_system_wait_semaphore() argument
37 status = acpi_os_wait_semaphore(semaphore, 1, ACPI_DO_NOT_WAIT); in acpi_ex_system_wait_semaphore()
47 status = acpi_os_wait_semaphore(semaphore, 1, timeout); in acpi_ex_system_wait_semaphore()
/linux-6.12.1/fs/jffs2/
DREADME.Locking141 This read/write semaphore protects against concurrent access to the
154 This read/write semaphore protects against concurrent access to the
156 In read-only path, write-semaphore is too much exclusion. It's enough
157 by read-semaphore. But you must hold write-semaphore when updating,
162 when updating such a object is necessary under holding read semaphore.
163 For example, do_jffs2_getxattr() holds read-semaphore to scan xref and
164 xdatum at first. But it retries this process with holding write-semaphore
165 after release read-semaphore, if it's necessary to load name/value pair
/linux-6.12.1/drivers/input/misc/
Dhp_sdc_rtc.c58 static struct semaphore i8042tregs;
68 struct semaphore tsem; in hp_sdc_rtc_do_read_bbrtc()
87 t.act.semaphore = &tsem; in hp_sdc_rtc_do_read_bbrtc()
159 t.act.semaphore = &i8042tregs; in hp_sdc_rtc_read_i8042timer()
/linux-6.12.1/Documentation/networking/
Dnetdevices.rst213 Synchronization: rtnl_lock() semaphore.
217 Synchronization: rtnl_lock() semaphore.
222 Synchronization: rtnl_lock() semaphore.
230 Synchronization: rtnl_lock() semaphore.
237 Synchronization: rtnl_lock() semaphore.
244 Synchronization: rtnl_lock() semaphore.
251 Synchronization: rtnl_lock() semaphore.
255 Synchronization: rtnl_lock() semaphore, or RCU.
/linux-6.12.1/drivers/md/dm-vdo/indexer/
Dsparse-cache.c145 struct semaphore lock;
147 struct semaphore wait;
178 static inline void __down(struct semaphore *semaphore) in __down() argument
184 while (down_interruptible(semaphore) != 0) { in __down()
/linux-6.12.1/drivers/staging/vc04_services/interface/vchiq_arm/
Dvchiq_arm.h48 struct semaphore free_fragments_sema;
49 struct semaphore free_fragments_mutex;
/linux-6.12.1/Documentation/locking/
Dpercpu-rw-semaphore.rst5 Percpu rw semaphores is a new read-write semaphore design that is
9 cores take the lock for reading, the cache line containing the semaphore
Dindex.rst24 percpu-rw-semaphore
/linux-6.12.1/Documentation/driver-api/serial/
Ddriver.rst44 There are two locks. A per-port spinlock, and an overall semaphore.
57 The port_sem semaphore is used to protect against ports being added/
59 semaphore has been the 'mutex' member of the tty_port struct, and
/linux-6.12.1/drivers/md/bcache/
Dbcache.h311 struct semaphore sb_write_mutex;
343 struct semaphore in_flight;
541 struct semaphore sb_write_mutex;
667 struct semaphore moving_in_flight;
684 struct semaphore uuid_write_mutex;
/linux-6.12.1/drivers/net/ethernet/huawei/hinic/
Dhinic_hw_mbox.h92 struct semaphore mbox_send_sem;
93 struct semaphore msg_send_sem;
/linux-6.12.1/Documentation/accel/qaic/
Daic100.rst352 semaphore command.
354 * Bit(31) indicates this semaphore command is enabled.
360 * Bits(26:24) are the semaphore command. 0 is NOP. 1 is init with the
362 until the semaphore is equal to the specified value. 5 is wait
363 until the semaphore is greater or equal to the specified value.
364 6 is "P", wait until semaphore is greater than 0, then
367 * Bit(22) is the semaphore sync. 0 is post sync, which means that the
368 semaphore operation is done after the DMA transfer. 1 is
372 * Bits(20:16) is the index of the semaphore to operate on.
374 * Bits(11:0) are the semaphore value to use in operations.
[all …]
/linux-6.12.1/drivers/acpi/
Dosl.c1196 struct semaphore *sem = NULL; in acpi_os_create_semaphore()
1198 sem = acpi_os_allocate_zeroed(sizeof(struct semaphore)); in acpi_os_create_semaphore()
1221 struct semaphore *sem = (struct semaphore *)handle; in acpi_os_delete_semaphore()
1241 struct semaphore *sem = (struct semaphore *)handle; in acpi_os_wait_semaphore()
1285 struct semaphore *sem = (struct semaphore *)handle; in acpi_os_signal_semaphore()

1234567