⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pthread_cond_timedwait.s

📁 glibc 2.9,最新版的C语言库函数
💻 S
📖 第 1 页 / 共 2 页
字号:
/* Copyright (C) 2003, 2004, 2006, 2007 Free Software Foundation, Inc.   This file is part of the GNU C Library.   The GNU C Library is free software; you can redistribute it and/or   modify it under the terms of the GNU Lesser General Public   License as published by the Free Software Foundation; either   version 2.1 of the License, or (at your option) any later version.   The GNU C Library is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU   Lesser General Public License for more details.   You should have received a copy of the GNU Lesser General Public   License along with the GNU C Library; if not, write to the Free   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA   02111-1307 USA.  */#include <sysdep.h>#include <shlib-compat.h>#include <lowlevellock.h>#include <lowlevelcond.h>#include <pthread-errnos.h>#include <kernel-features.h>#include <tcb-offsets.h>#include "lowlevel-atomic.h"	.text/* int pthread_cond_timedwait (pthread_cond_t *cond, pthread_mutex_t *mutex,			       const struct timespec *abstime)  */	.globl	__pthread_cond_timedwait	.type	__pthread_cond_timedwait, @function	.align	5__pthread_cond_timedwait:.LSTARTCODE:	mov.l	r8, @-r15.Lpush_r8:	mov.l	r9, @-r15.Lpush_r9:	mov.l	r10, @-r15.Lpush_r10:	mov.l	r11, @-r15.Lpush_r11:	mov.l	r12, @-r15.Lpush_r12:	mov.l	r13, @-r15.Lpush_r13:	sts.l	pr, @-r15.Lpush_pr:	add	#-64, r15.Lalloc:	mov	r4, r8	mov	r5, r9	mov	r6, r13#ifdef PIC	mova	.Lgot0, r0	mov.l	.Lgot0, r12	add	r0, r12#endif	mov.l	@(4,r13), r0	mov.l	.L1g, r1	cmp/hs	r1, r0	bf	0f	bra	18f	 mov	#EINVAL, r00:	/* Get internal lock.  */	mov	#0, r3	mov	#1, r4#if cond_lock != 0	CMPXCHG (r3, @(cond_lock,r8), r4, r2)#else	CMPXCHG (r3, @r8, r4, r2)#endif	bt	2f	bra	1f	 nop#ifdef PIC	.align	2.Lgot0:	.long	_GLOBAL_OFFSET_TABLE_#endif2:	/* Store the reference to the mutex.  If there is already a	   different value in there this is a bad user bug.  */	mov.l	@(dep_mutex,r8),r0	cmp/eq	#-1, r0	bt	17f	mov.l	r9, @(dep_mutex,r8)17:		/* Unlock the mutex.  */	mov.l	.Lmunlock1, r1	mov	#0, r5	bsrf	r1	 mov	r9, r4.Lmunlock1b:	tst	r0, r0	bt	0f	bra	16f	 nop0:	mov	#1, r2	mov	#0, r3	clrt	mov.l	@(total_seq,r8),r0	mov.l	@(total_seq+4,r8),r1	addc	r2, r0	addc	r3, r1	mov.l	r0,@(total_seq,r8)	mov.l	r1,@(total_seq+4,r8)	mov.l	@(cond_futex,r8), r0	add	r2, r0	mov.l	r0, @(cond_futex,r8)	mov	#(1 << nwaiters_shift), r2	mov.l	@(cond_nwaiters,r8), r0	add	r2, r0	mov.l	r0, @(cond_nwaiters,r8)		/* Get and store current wakeup_seq value.  */	mov.l	@(wakeup_seq,r8), r10	mov.l	@(wakeup_seq+4,r8), r11	mov.l	@(broadcast_seq,r8), r0	mov.l	r0, @(4,r15)8:		/* Get current time.  */#ifdef __NR_clock_gettime	/* Get the clock number.	 */	mov.l	@(cond_nwaiters,r8), r4	mov	#((1 << nwaiters_shift) - 1), r0	and	r0, r4	/* Only clocks 0 and 1 are allowed.  Both are handled in the	   kernel.  */	mov	r15, r5	add	#16, r5	mov.w	.L__NR_clock_gettime, r3	trapa	#0x12	SYSCALL_INST_PAD# ifndef __ASSUME_POSIX_TIMERS	cmp/eq	#-ENOSYS, r0	bt	19f# endif	/* Compute relative timeout.  */	mov.l	@r13, r2	mov.l	@(4,r13), r3	mov.l	@(16,r15), r0	bra	0f	 mov.l	@(20,r15), r1.L__NR_clock_gettime:	.word	__NR_clock_gettime# ifndef __ASSUME_POSIX_TIMERS19:		mov	r15, r4	add	#16, r4	mov	#0, r5	mov	#__NR_gettimeofday, r3	trapa	#0x12	SYSCALL_INST_PAD	/* Compute relative timeout.  */	mov.l	@(20,r15), r0	mov.w	.L1k, r1	dmulu.l	r0, r1		/* Micro seconds to nano seconds.  */	mov.l	@r13, r2	mov.l	@(4,r13), r3	mov.l	@(16,r15), r0	sts	macl, r1#endif0:	#else	mov	r15, r4	add	#16, r4	mov	#0, r5	mov	#__NR_gettimeofday, r3	trapa	#0x12	SYSCALL_INST_PAD	/* Compute relative timeout.  */	mov.l	@(20,r15), r0	mov.w	.L1k, r1	dmulu.l	r0, r1		/* Micro seconds to nano seconds.  */	mov.l	@r13, r2	mov.l	@(4,r13), r3	mov.l	@(16,r15), r0	sts	macl, r1#endif	sub	r0, r2	clrt	subc	r1, r3	bf	12f	mov.l	.L1g, r1	add	r1, r3	add	#-1, r212:	mov	#-ETIMEDOUT, r1	mov.l	r1, @(12,r15)	cmp/pz	r2	bf	6f		/* Time is already up.  */	/* Store relative timeout.  */	mov.l	r2, @(16,r15)	mov.l	r3, @(20,r15)	mov.l	@(cond_futex,r8), r1	mov.l	r1, @(8,r15)	/* Unlock.  */#if cond_lock != 0	DEC (@(cond_lock,r8), r2)#else	DEC (@r8, r2)#endif	tst	r2, r2	bt	4f	bra	3f	 nop4:.LcleanupSTART:	mov.l	.Lenable1, r1	bsrf	r1	 nop.Lenable1b:	mov.l	r0, @r15	mov	r15, r7	add	#16, r7	mov.l	@(dep_mutex,r8), r0	cmp/eq	#-1, r0	bt/s	99f	 mov	#FUTEX_WAIT, r5#ifdef __ASSUME_PRIVATE_FUTEX	mov	#(FUTEX_WAIT|FUTEX_PRIVATE_FLAG), r5	extu.b	r5, r5#else	stc	gbr, r1	mov.w	.Lpfoff, r2	add	r2, r1	mov.l	@r1, r5	mov	#FUTEX_WAIT, r0	or	r0, r5#endif99:		mov.l	@(8,r15), r6	mov	r8, r4	add	#cond_futex, r4	mov	#SYS_futex, r3	extu.b	r3, r3	trapa	#0x14	SYSCALL_INST_PAD	mov.l	r0, @(12,r15)	mov.l	.Ldisable1, r1	bsrf	r1	 mov.l	@r15, r4.Ldisable1b:.LcleanupEND:	/* Lock.  */	mov	#0, r3	mov	#1, r4#if cond_lock != 0	CMPXCHG (r3, @(cond_lock,r8), r4, r2)#else	CMPXCHG (r3, @r8, r4, r2)#endif	bf	5f6:	mov.l	@(broadcast_seq,r8), r0	mov.l	@(4,r15), r1	cmp/eq	r0, r1	bf	23f	mov.l	@(woken_seq,r8), r0	mov.l	@(woken_seq+4,r8), r1	mov.l	@(wakeup_seq,r8), r2	mov.l	@(wakeup_seq+4,r8), r3	cmp/eq	r3, r11	bf	7f	cmp/eq	r2, r10	bt	15f7:	cmp/eq	r1, r3	bf	9f	cmp/eq	r0, r2	bf	9f15:	mov.l	@(12,r15),r0	cmp/eq	#-ETIMEDOUT, r0	bf	8b	mov	#1, r2	mov	#0, r3	clrt	mov.l	@(wakeup_seq,r8),r0	mov.l	@(wakeup_seq+4,r8),r1	addc	r2, r0	addc	r3, r1	mov.l	r0,@(wakeup_seq,r8)	mov.l	r1,@(wakeup_seq+4,r8)	mov.l	@(cond_futex,r8),r0	add	r2, r0	mov.l	r0,@(cond_futex,r8)	mov	#ETIMEDOUT, r0	bra	14f	 mov.l	r0, @(24,r15)23:	mov	#0, r0	bra	24f	 mov.l	r0, @(24,r15)9:	mov	#0, r0	mov.l	r0, @(24,r15)14:	mov	#1, r2	mov	#0, r3	clrt	mov.l	@(woken_seq,r8),r0	mov.l	@(woken_seq+4,r8),r1	addc	r2, r0	addc	r3, r1	mov.l	r0,@(woken_seq,r8)	mov.l	r1,@(woken_seq+4,r8)24:	mov	#(1 << nwaiters_shift), r2	mov.l	@(cond_nwaiters,r8),r0	sub	r2, r0	mov.l	r0,@(cond_nwaiters,r8)	/* Wake up a thread which wants to destroy the condvar object.  */	mov.l	@(total_seq,r8),r0	mov.l	@(total_seq+4,r8),r1	and	r1, r0	not	r0, r0	cmp/eq	#0, r0	bf/s	25f	 mov	#((1 << nwaiters_shift) - 1), r1	not	r1, r1	mov.l	@(cond_nwaiters,r8),r0	tst	r1, r0	bf	25f	mov	r8, r4	add	#cond_nwaiters, r4	mov.l	@(dep_mutex,r8), r0	cmp/eq	#-1, r0	bt/s	99f	 mov	#FUTEX_WAKE, r5#ifdef __ASSUME_PRIVATE_FUTEX	mov	#(FUTEX_WAKE|FUTEX_PRIVATE_FLAG), r5	extu.b	r5, r5#else	stc	gbr, r1	mov.w	.Lpfoff, r2	add	r2, r1	mov.l	@r1, r5	mov	#FUTEX_WAKE, r0	or	r0, r5#endif99:		mov	#1, r6	mov	#0, r7	mov	#SYS_futex, r3	extu.b	r3, r3	trapa	#0x14	SYSCALL_INST_PAD	25:	#if cond_lock != 0	DEC (@(cond_lock,r8), r2)#else	DEC (@r8, r2)#endif	tst	r2, r2	bf	10f11:	mov	r9, r4	mov.l	.Lmlocki1, r1	bsrf	r1	 nop.Lmlocki1b:	/* We return the result of the mutex_lock operation if it failed.  */	tst	r0, r0	bf	18f	mov.l	@(24,r15), r018:		add	#64, r15	lds.l	@r15+, pr	mov.l	@r15+, r13	mov.l	@r15+, r12	mov.l	@r15+, r11	mov.l	@r15+, r10	mov.l	@r15+, r9	rts	 mov.l	@r15+, r8#ifndef __ASSUME_PRIVATE_FUTEX.Lpfoff:	.word	PRIVATE_FUTEX - TLS_PRE_TCB_SIZE#endif.L1k:	.word	1000	.align	2.Lmunlock1:	.long	__pthread_mutex_unlock_usercnt-.Lmunlock1b.Lenable1:	.long	__pthread_enable_asynccancel-.Lenable1b.Ldisable1:	.long	__pthread_disable_asynccancel-.Ldisable1b.Lmlocki1:	.long	__pthread_mutex_cond_lock-.Lmlocki1b.L1g:	.long	10000000001:	/* Initial locking failed.  */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -