_lwp.c revision 1.4
11.4Sskrll/* $NetBSD: _lwp.c,v 1.4 2010/01/07 12:31:10 skrll Exp $ */ 21.1Schs 31.1Schs/* 41.1Schs * Copyright (c) 2001 The NetBSD Foundation, Inc. 51.1Schs * All rights reserved. 61.1Schs * 71.1Schs * This code is derived from software contributed to The NetBSD Foundation 81.1Schs * by Wayne Knowles 91.1Schs * 101.1Schs * Redistribution and use in source and binary forms, with or without 111.1Schs * modification, are permitted provided that the following conditions 121.1Schs * are met: 131.1Schs * 1. Redistributions of source code must retain the above copyright 141.1Schs * notice, this list of conditions and the following disclaimer. 151.1Schs * 2. Redistributions in binary form must reproduce the above copyright 161.1Schs * notice, this list of conditions and the following disclaimer in the 171.1Schs * documentation and/or other materials provided with the distribution. 181.1Schs * 191.1Schs * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 201.1Schs * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 211.1Schs * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 221.1Schs * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 231.1Schs * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 241.1Schs * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 251.1Schs * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 261.1Schs * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 271.1Schs * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 281.1Schs * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 291.1Schs * POSSIBILITY OF SUCH DAMAGE. 301.1Schs */ 311.1Schs 321.2Slukem#include <sys/cdefs.h> 331.2Slukem#if defined(LIBC_SCCS) && !defined(lint) 341.4Sskrll__RCSID("$NetBSD: _lwp.c,v 1.4 2010/01/07 12:31:10 skrll Exp $"); 351.2Slukem#endif /* LIBC_SCCS and not lint */ 361.2Slukem 371.1Schs#include "namespace.h" 381.1Schs#include <sys/types.h> 391.1Schs#include <ucontext.h> 401.1Schs#include <lwp.h> 411.1Schs#include <stdlib.h> 421.1Schs#include <machine/frame.h> 431.1Schs 441.1Schsvoid 451.1Schs_lwp_makecontext(ucontext_t *u, void (*start)(void *), 461.1Schs void *arg, void *private, caddr_t stack_base, size_t stack_size) 471.1Schs{ 481.1Schs caddr_t sp; 491.1Schs __greg_t *gr; 501.4Sskrll __greg_t *gp; 511.4Sskrll __greg_t fp; 521.1Schs 531.1Schs getcontext(u); 541.1Schs gr = u->uc_mcontext.__gregs; 551.1Schs u->uc_link = NULL; 561.1Schs 571.1Schs u->uc_stack.ss_sp = stack_base; 581.1Schs u->uc_stack.ss_size = stack_size; 591.1Schs sp = stack_base + HPPA_FRAME_SIZE; 601.1Schs 611.4Sskrll fp = (__greg_t)start; 621.4Sskrll if (fp & 2) { 631.4Sskrll gp = (__greg_t *)(fp & ~3); 641.4Sskrll fp = gp[0]; 651.4Sskrll gr[_REG_R19] = gp[1]; 661.4Sskrll } 671.4Sskrll gr[_REG_PCOQH] = fp | HPPA_PC_PRIV_USER; 681.4Sskrll gr[_REG_PCOQT] = (fp + 4) | HPPA_PC_PRIV_USER; 691.1Schs gr[_REG_RP] = (__greg_t) _lwp_exit; 701.1Schs gr[_REG_ARG0] = (__greg_t) arg; 711.1Schs gr[_REG_SP] = (__greg_t) sp; 721.1Schs} 73