ashldi3.c revision 1541
11541Srgrimes/*- 21541Srgrimes * Copyright (c) 1992, 1993 31541Srgrimes * The Regents of the University of California. All rights reserved. 41541Srgrimes * 51541Srgrimes * This software was developed by the Computer Systems Engineering group 61541Srgrimes * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and 71541Srgrimes * contributed to Berkeley. 81541Srgrimes * 91541Srgrimes * Redistribution and use in source and binary forms, with or without 101541Srgrimes * modification, are permitted provided that the following conditions 111541Srgrimes * are met: 121541Srgrimes * 1. Redistributions of source code must retain the above copyright 131541Srgrimes * notice, this list of conditions and the following disclaimer. 141541Srgrimes * 2. Redistributions in binary form must reproduce the above copyright 151541Srgrimes * notice, this list of conditions and the following disclaimer in the 161541Srgrimes * documentation and/or other materials provided with the distribution. 171541Srgrimes * 3. All advertising materials mentioning features or use of this software 181541Srgrimes * must display the following acknowledgement: 191541Srgrimes * This product includes software developed by the University of 201541Srgrimes * California, Berkeley and its contributors. 211541Srgrimes * 4. Neither the name of the University nor the names of its contributors 221541Srgrimes * may be used to endorse or promote products derived from this software 231541Srgrimes * without specific prior written permission. 241541Srgrimes * 251541Srgrimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 261541Srgrimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 271541Srgrimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 281541Srgrimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 291541Srgrimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 301541Srgrimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 311541Srgrimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 321541Srgrimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 331541Srgrimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 341541Srgrimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 351541Srgrimes * SUCH DAMAGE. 361541Srgrimes */ 371541Srgrimes 381541Srgrimes#if defined(LIBC_SCCS) && !defined(lint) 391541Srgrimesstatic char sccsid[] = "@(#)ashldi3.c 8.1 (Berkeley) 6/4/93"; 401541Srgrimes#endif /* LIBC_SCCS and not lint */ 411541Srgrimes 421541Srgrimes#include "quad.h" 431541Srgrimes 441541Srgrimes/* 451541Srgrimes * Shift a (signed) quad value left (arithmetic shift left). 461541Srgrimes * This is the same as logical shift left! 471541Srgrimes */ 481541Srgrimesquad_t 491541Srgrimes__ashldi3(a, shift) 501541Srgrimes quad_t a; 511541Srgrimes qshift_t shift; 521541Srgrimes{ 531541Srgrimes union uu aa; 541541Srgrimes 551541Srgrimes aa.q = a; 561541Srgrimes if (shift >= LONG_BITS) { 571541Srgrimes aa.ul[H] = shift >= QUAD_BITS ? 0 : 581541Srgrimes aa.ul[L] << (shift - LONG_BITS); 591541Srgrimes aa.ul[L] = 0; 601541Srgrimes } else if (shift > 0) { 611541Srgrimes aa.ul[H] = (aa.ul[H] << shift) | 621541Srgrimes (aa.ul[L] >> (LONG_BITS - shift)); 631541Srgrimes aa.ul[L] <<= shift; 641541Srgrimes } 651541Srgrimes return (aa.q); 661541Srgrimes} 67