17c478bd9Sstevel@tonic-gate /* 27c478bd9Sstevel@tonic-gate * CDDL HEADER START 37c478bd9Sstevel@tonic-gate * 47c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5*a574db85Sraf * Common Development and Distribution License (the "License"). 6*a574db85Sraf * You may not use this file except in compliance with the License. 77c478bd9Sstevel@tonic-gate * 87c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 97c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 107c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions 117c478bd9Sstevel@tonic-gate * and limitations under the License. 127c478bd9Sstevel@tonic-gate * 137c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 147c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 157c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 167c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 177c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 187c478bd9Sstevel@tonic-gate * 197c478bd9Sstevel@tonic-gate * CDDL HEADER END 207c478bd9Sstevel@tonic-gate */ 21*a574db85Sraf 227c478bd9Sstevel@tonic-gate /* 23*a574db85Sraf * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 24*a574db85Sraf * Use is subject to license terms. 257c478bd9Sstevel@tonic-gate */ 267c478bd9Sstevel@tonic-gate 277c478bd9Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 287c478bd9Sstevel@tonic-gate 297c478bd9Sstevel@tonic-gate #include <sys/isa_defs.h> 307c478bd9Sstevel@tonic-gate 317c478bd9Sstevel@tonic-gate #include <stdlib.h> 327c478bd9Sstevel@tonic-gate #include <unistd.h> 337c478bd9Sstevel@tonic-gate #include <string.h> 347c478bd9Sstevel@tonic-gate #include <errno.h> 357c478bd9Sstevel@tonic-gate #include <sys/types.h> 367c478bd9Sstevel@tonic-gate #include <sys/wait.h> 377c478bd9Sstevel@tonic-gate 387c478bd9Sstevel@tonic-gate #include "P32ton.h" 397c478bd9Sstevel@tonic-gate #include "libproc.h" 407c478bd9Sstevel@tonic-gate 417c478bd9Sstevel@tonic-gate /* 427c478bd9Sstevel@tonic-gate * waitid() system call -- executed by subject process 437c478bd9Sstevel@tonic-gate */ 447c478bd9Sstevel@tonic-gate int 457c478bd9Sstevel@tonic-gate pr_waitid(struct ps_prochandle *Pr, 467c478bd9Sstevel@tonic-gate idtype_t idtype, id_t id, siginfo_t *infop, int options) 477c478bd9Sstevel@tonic-gate { 487c478bd9Sstevel@tonic-gate sysret_t rval; /* return value from waitid() */ 497c478bd9Sstevel@tonic-gate argdes_t argd[4]; /* arg descriptors for waitid() */ 507c478bd9Sstevel@tonic-gate argdes_t *adp; 517c478bd9Sstevel@tonic-gate int error; 527c478bd9Sstevel@tonic-gate #ifdef _LP64 537c478bd9Sstevel@tonic-gate siginfo32_t siginfo32; 547c478bd9Sstevel@tonic-gate #endif /* _LP64 */ 557c478bd9Sstevel@tonic-gate 567c478bd9Sstevel@tonic-gate if (Pr == NULL) /* no subject process */ 577c478bd9Sstevel@tonic-gate return (waitid(idtype, id, infop, options)); 587c478bd9Sstevel@tonic-gate 597c478bd9Sstevel@tonic-gate adp = &argd[0]; /* idtype argument */ 607c478bd9Sstevel@tonic-gate adp->arg_value = idtype; 617c478bd9Sstevel@tonic-gate adp->arg_object = NULL; 627c478bd9Sstevel@tonic-gate adp->arg_type = AT_BYVAL; 637c478bd9Sstevel@tonic-gate adp->arg_inout = AI_INPUT; 647c478bd9Sstevel@tonic-gate adp->arg_size = 0; 657c478bd9Sstevel@tonic-gate 667c478bd9Sstevel@tonic-gate adp++; /* id argument */ 677c478bd9Sstevel@tonic-gate adp->arg_value = id; 687c478bd9Sstevel@tonic-gate adp->arg_object = NULL; 697c478bd9Sstevel@tonic-gate adp->arg_type = AT_BYVAL; 707c478bd9Sstevel@tonic-gate adp->arg_inout = AI_INPUT; 717c478bd9Sstevel@tonic-gate adp->arg_size = 0; 727c478bd9Sstevel@tonic-gate 737c478bd9Sstevel@tonic-gate adp++; /* infop argument */ 747c478bd9Sstevel@tonic-gate adp->arg_value = 0; 757c478bd9Sstevel@tonic-gate adp->arg_type = AT_BYREF; 767c478bd9Sstevel@tonic-gate adp->arg_inout = AI_OUTPUT; 777c478bd9Sstevel@tonic-gate #ifdef _LP64 787c478bd9Sstevel@tonic-gate if (Pstatus(Pr)->pr_dmodel == PR_MODEL_ILP32) { 797c478bd9Sstevel@tonic-gate adp->arg_object = &siginfo32; 807c478bd9Sstevel@tonic-gate adp->arg_size = sizeof (siginfo32); 817c478bd9Sstevel@tonic-gate } else { 827c478bd9Sstevel@tonic-gate adp->arg_object = infop; 837c478bd9Sstevel@tonic-gate adp->arg_size = sizeof (*infop); 847c478bd9Sstevel@tonic-gate } 857c478bd9Sstevel@tonic-gate #else /* _LP64 */ 867c478bd9Sstevel@tonic-gate adp->arg_object = infop; 877c478bd9Sstevel@tonic-gate adp->arg_size = sizeof (*infop); 887c478bd9Sstevel@tonic-gate #endif /* _LP64 */ 897c478bd9Sstevel@tonic-gate 907c478bd9Sstevel@tonic-gate adp++; /* options argument */ 917c478bd9Sstevel@tonic-gate adp->arg_value = options; 927c478bd9Sstevel@tonic-gate adp->arg_object = NULL; 937c478bd9Sstevel@tonic-gate adp->arg_type = AT_BYVAL; 947c478bd9Sstevel@tonic-gate adp->arg_inout = AI_INPUT; 957c478bd9Sstevel@tonic-gate adp->arg_size = 0; 967c478bd9Sstevel@tonic-gate 97*a574db85Sraf error = Psyscall(Pr, &rval, SYS_waitid, 4, &argd[0]); 987c478bd9Sstevel@tonic-gate 997c478bd9Sstevel@tonic-gate if (error) { 1007c478bd9Sstevel@tonic-gate errno = (error > 0)? error : ENOSYS; 1017c478bd9Sstevel@tonic-gate return (-1); 1027c478bd9Sstevel@tonic-gate } 1037c478bd9Sstevel@tonic-gate #ifdef _LP64 1047c478bd9Sstevel@tonic-gate if (Pstatus(Pr)->pr_dmodel == PR_MODEL_ILP32) 1057c478bd9Sstevel@tonic-gate siginfo_32_to_n(&siginfo32, infop); 1067c478bd9Sstevel@tonic-gate #endif /* _LP64 */ 1077c478bd9Sstevel@tonic-gate return (0); 1087c478bd9Sstevel@tonic-gate } 109