pthread_md.h revision 1.5
11.5Sad/* $NetBSD: pthread_md.h,v 1.5 2008/02/10 18:50:55 ad Exp $ */ 21.2Sthorpej 31.2Sthorpej/*- 41.2Sthorpej * Copyright (c) 2002 The NetBSD Foundation, Inc. 51.2Sthorpej * All rights reserved. 61.2Sthorpej * 71.2Sthorpej * Redistribution and use in source and binary forms, with or without 81.2Sthorpej * modification, are permitted provided that the following conditions 91.2Sthorpej * are met: 101.2Sthorpej * 1. Redistributions of source code must retain the above copyright 111.2Sthorpej * notice, this list of conditions and the following disclaimer. 121.2Sthorpej * 2. Redistributions in binary form must reproduce the above copyright 131.2Sthorpej * notice, this list of conditions and the following disclaimer in the 141.2Sthorpej * documentation and/or other materials provided with the distribution. 151.2Sthorpej * 3. All advertising materials mentioning features or use of this software 161.2Sthorpej * must display the following acknowledgement: 171.2Sthorpej * This product includes software developed by the NetBSD 181.2Sthorpej * Foundation, Inc. and its contributors. 191.2Sthorpej * 4. Neither the name of The NetBSD Foundation nor the names of its 201.2Sthorpej * contributors may be used to endorse or promote products derived 211.2Sthorpej * from this software without specific prior written permission. 221.2Sthorpej * 231.2Sthorpej * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 241.2Sthorpej * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 251.2Sthorpej * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 261.2Sthorpej * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 271.2Sthorpej * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 281.2Sthorpej * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 291.2Sthorpej * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 301.2Sthorpej * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 311.2Sthorpej * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 321.2Sthorpej * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 331.2Sthorpej * POSSIBILITY OF SUCH DAMAGE. 341.2Sthorpej */ 351.2Sthorpej 361.2Sthorpej#ifndef _LIB_PTHREAD_SPARC_MD_H 371.2Sthorpej#define _LIB_PTHREAD_SPARC_MD_H 381.2Sthorpej 391.2Sthorpej/* 401.2Sthorpej * pthread__sp used for identifying thread 411.2Sthorpej */ 421.4Sperrystatic inline long 431.2Sthorpejpthread__sp(void) 441.2Sthorpej{ 451.2Sthorpej long ret; 461.2Sthorpej 471.2Sthorpej __asm("mov %%sp, %0" : "=r" (ret)); 481.2Sthorpej 491.2Sthorpej return ret; 501.2Sthorpej} 511.2Sthorpej 521.2Sthorpej#define pthread__uc_sp(ucp) ((ucp)->uc_mcontext.__gregs[_REG_O6]) 531.2Sthorpej#define pthread__uc_pc(ucp) ((ucp)->uc_mcontext.__gregs[_REG_PC]) 541.2Sthorpej 551.2Sthorpej#define STACKSPACE 96 /* min stack frame XXX */ 561.2Sthorpej 571.2Sthorpej/* 581.2Sthorpej * Conversions between struct reg and struct mcontext. Used by 591.2Sthorpej * libpthread_dbg. 601.2Sthorpej * XXX macros 611.2Sthorpej */ 621.2Sthorpej 631.2Sthorpej#define PTHREAD_UCONTEXT_TO_REG(reg, uc) do { \ 641.3Smartin memcpy((reg), &(uc)->uc_mcontext.__gregs, \ 651.3Smartin (_REG_Y+1)*sizeof(__greg_t)); \ 661.3Smartin (reg)->r_global[0] = 0; \ 671.3Smartin memcpy(&(reg)->r_global[1], &(uc)->uc_mcontext.__gregs[_REG_G1],\ 681.3Smartin (_REG_O7-_REG_G1+1)*sizeof(__greg_t)); \ 691.2Sthorpej } while (/*CONSTCOND*/0) 701.2Sthorpej 711.2Sthorpej#define PTHREAD_REG_TO_UCONTEXT(uc, reg) do { \ 721.3Smartin memcpy(&(uc)->uc_mcontext.__gregs, (reg), \ 731.3Smartin (_REG_Y+1)*sizeof(__greg_t)); \ 741.3Smartin (uc)->uc_mcontext.__gregs[_REG_Y] = (reg)->r_y; \ 751.3Smartin memcpy(&(uc)->uc_mcontext.__gregs[_REG_G1], &(reg)->r_global[1],\ 761.3Smartin (_REG_O7-_REG_G1+1)*sizeof(__greg_t)); \ 771.2Sthorpej (uc)->uc_flags = ((uc)->uc_flags | _UC_CPU) & ~_UC_USER; \ 781.2Sthorpej } while (/*CONSTCOND*/0) 791.2Sthorpej 801.3Smartin#define PTHREAD_UCONTEXT_TO_FPREG(freg, uc) do { \ 811.3Smartin memcpy((freg)->fr_regs, \ 821.3Smartin &(uc)->uc_mcontext.__fpregs.__fpu_fr.__fpu_regs, \ 831.3Smartin 32*sizeof(u_int)); \ 841.3Smartin (freg)->fr_fsr = (uc)->uc_mcontext.__fpregs.__fpu_fsr; \ 851.3Smartin } while (/*CONSTCOND*/0) 861.2Sthorpej 871.2Sthorpej#define PTHREAD_FPREG_TO_UCONTEXT(uc, freg) do { \ 881.3Smartin memcpy(&(uc)->uc_mcontext.__fpregs.__fpu_fr.__fpu_regs, \ 891.3Smartin (freg)->fr_regs, \ 901.3Smartin 32*sizeof(u_int)); \ 911.3Smartin (uc)->uc_mcontext.__fpregs.__fpu_fsr = (freg)->fr_fsr; \ 921.2Sthorpej (uc)->uc_flags = ((uc)->uc_flags | _UC_FPU) & ~_UC_USER; \ 931.2Sthorpej } while (/*CONSTCOND*/0) 941.2Sthorpej 951.5Sad/* Don't need additional memory barriers. */ 961.5Sad#define PTHREAD__ATOMIC_IS_MEMBAR 971.5Sad 981.2Sthorpej#endif /* _LIB_PTHREAD_SPARC_MD_H */ 99