Home | History | Annotate | Line # | Download | only in common
compat_sigaltstack.h revision 1.1.2.4
      1 /*      $NetBSD: compat_sigaltstack.h,v 1.1.2.4 2007/07/15 13:27:00 ad Exp $        */
      2 
      3 /* Wrapper for calling sigaltstack1() from compat (or other) code */
      4 
      5 /* Maybe these definitions could be global. */
      6 #ifdef SCARG_P32
      7 /* compat32 */
      8 #define	SCARG_COMPAT_PTR(uap,p)	SCARG_P32(uap, p)
      9 #define	COMPAT_GET_PTR(p)	NETBSD32PTR64(p)
     10 #define	COMPAT_SET_PTR(p, v)	NETBSD32PTR32(p, v)
     11 #else
     12 /* not a size change */
     13 #define	SCARG_COMPAT_PTR(uap,p)	SCARG(uap, p)
     14 #define	COMPAT_GET_PTR(p)	(p)
     15 #define	COMPAT_SET_PTR(p, v)	((p) = (v))
     16 #endif
     17 
     18 #define compat_sigaltstack(uap, compat_ss, ss_onstack, ss_disable) do { \
     19 	struct compat_ss css; \
     20 	struct sigaltstack nss, oss; \
     21 	int error; \
     22 \
     23 	if (SCARG_COMPAT_PTR(uap, nss)) { \
     24 		error = copyin(SCARG_COMPAT_PTR(uap, nss), &css, sizeof css); \
     25 		if (error) \
     26 			return error; \
     27 		nss.ss_sp = COMPAT_GET_PTR(css.ss_sp); \
     28 		nss.ss_size = css.ss_size; \
     29 		if (ss_onstack == SS_ONSTACK && ss_disable == SS_DISABLE) \
     30 			nss.ss_flags = css.ss_flags; \
     31 		else \
     32 			nss.ss_flags = \
     33 			    (css.ss_flags & ss_onstack ? SS_ONSTACK : 0) \
     34 			    | (css.ss_flags & ss_disable ? SS_DISABLE : 0); \
     35 	} \
     36 \
     37 	error = sigaltstack1(l, SCARG_COMPAT_PTR(uap, nss) ? &nss : 0, \
     38 				SCARG_COMPAT_PTR(uap, oss) ? &oss : 0); \
     39 	if (error) \
     40 		return (error); \
     41 \
     42 	if (SCARG_COMPAT_PTR(uap, oss)) { \
     43 		COMPAT_SET_PTR(css.ss_sp, oss.ss_sp); \
     44 		css.ss_size = oss.ss_size; \
     45 		if (ss_onstack == SS_ONSTACK && ss_disable == SS_DISABLE) \
     46 			css.ss_flags = oss.ss_flags; \
     47 		else \
     48 			css.ss_flags = \
     49 			    (oss.ss_flags & SS_ONSTACK ? ss_onstack : 0) \
     50 			    | (oss.ss_flags & SS_DISABLE ? ss_disable : 0); \
     51 		error = copyout(&css, SCARG_COMPAT_PTR(uap, oss), sizeof(css));\
     52 		if (error) \
     53 			return (error); \
     54 	} \
     55 	return (0); \
     56 } while (0)
     57 /*      $NetBSD: compat_sigaltstack.h,v 1.1.2.4 2007/07/15 13:27:00 ad Exp $        */
     58 
     59 /* Wrapper for calling sigaltstack1() from compat (or other) code */
     60 
     61 /* Maybe these definitions could be global. */
     62 #ifdef SCARG_P32
     63 /* compat32 */
     64 #define	SCARG_COMPAT_PTR(uap,p)	SCARG_P32(uap, p)
     65 #define	COMPAT_GET_PTR(p)	NETBSD32PTR64(p)
     66 #define	COMPAT_SET_PTR(p, v)	NETBSD32PTR32(p, v)
     67 #else
     68 /* not a size change */
     69 #define	SCARG_COMPAT_PTR(uap,p)	SCARG(uap, p)
     70 #define	COMPAT_GET_PTR(p)	(p)
     71 #define	COMPAT_SET_PTR(p, v)	((p) = (v))
     72 #endif
     73 
     74 #define compat_sigaltstack(uap, compat_ss) do { \
     75 	struct compat_ss css; \
     76 	struct sigaltstack nss, oss; \
     77 	int error; \
     78 \
     79 	if (SCARG_COMPAT_PTR(uap, nss)) { \
     80 		error = copyin(SCARG_COMPAT_PTR(uap, nss), &css, sizeof css); \
     81 		if (error) \
     82 			return error; \
     83 		 nss.ss_sp = COMPAT_GET_PTR(css.ss_sp); \
     84 		 nss.ss_size = css.ss_size; \
     85 		 nss.ss_flags = css.ss_flags; \
     86 	} \
     87 \
     88 	error = sigaltstack1(l, SCARG_COMPAT_PTR(uap, nss) ? &nss : 0, \
     89 				SCARG_COMPAT_PTR(uap, oss) ? &oss : 0); \
     90 	if (error) \
     91 		return (error); \
     92 \
     93 	if (SCARG_COMPAT_PTR(uap, oss)) { \
     94 		COMPAT_SET_PTR(css.ss_sp, oss.ss_sp); \
     95 		css.ss_size = oss.ss_size; \
     96 		css.ss_flags = oss.ss_flags; \
     97 		error = copyout(&css, SCARG_COMPAT_PTR(uap, oss), sizeof(css)); \
     98 		if (error) \
     99 			return (error); \
    100 	} \
    101 	return (0); \
    102 } while (0)
    103