|  | /* More subroutines needed by GCC output code on some machines.  */ | 
|  | /* Compile this one with gcc.  */ | 
|  | /* Copyright (C) 1989, 92-98, 1999 Free Software Foundation, Inc. | 
|  |  | 
|  | This file is part of GNU CC. | 
|  |  | 
|  | GNU CC is free software; you can redistribute it and/or modify | 
|  | it under the terms of the GNU General Public License as published by | 
|  | the Free Software Foundation; either version 2, or (at your option) | 
|  | any later version. | 
|  |  | 
|  | GNU CC is distributed in the hope that it will be useful, | 
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | GNU General Public License for more details. | 
|  |  | 
|  | You should have received a copy of the GNU General Public License | 
|  | along with GNU CC; see the file COPYING.  If not, write to | 
|  | the Free Software Foundation, 59 Temple Place - Suite 330, | 
|  | Boston, MA 02111-1307, USA.  */ | 
|  |  | 
|  | /* As a special exception, if you link this library with other files, | 
|  | some of which are compiled with GCC, to produce an executable, | 
|  | this library does not by itself cause the resulting executable | 
|  | to be covered by the GNU General Public License. | 
|  | This exception does not however invalidate any other reasons why | 
|  | the executable file might be covered by the GNU General Public License. | 
|  | */ | 
|  | /* support functions required by the kernel. based on code from gcc-2.95.3 */ | 
|  | /* I Molton     29/07/01 */ | 
|  |  | 
|  | #include "gcclib.h" | 
|  |  | 
|  | #define umul_ppmm(xh, xl, a, b) \ | 
|  | {register u32 __t0, __t1, __t2;                                     \ | 
|  | __asm__ ("%@ Inlined umul_ppmm					\n\ | 
|  | mov     %2, %5, lsr #16						\n\ | 
|  | mov     %0, %6, lsr #16						\n\ | 
|  | bic     %3, %5, %2, lsl #16					\n\ | 
|  | bic     %4, %6, %0, lsl #16					\n\ | 
|  | mul     %1, %3, %4						\n\ | 
|  | mul     %4, %2, %4						\n\ | 
|  | mul     %3, %0, %3						\n\ | 
|  | mul     %0, %2, %0						\n\ | 
|  | adds    %3, %4, %3						\n\ | 
|  | addcs   %0, %0, #65536						\n\ | 
|  | adds    %1, %1, %3, lsl #16					\n\ | 
|  | adc     %0, %0, %3, lsr #16"                                    \ | 
|  | : "=&r" ((u32) (xh)),                                    \ | 
|  | "=r" ((u32) (xl)),                                     \ | 
|  | "=&r" (__t0), "=&r" (__t1), "=r" (__t2)                    \ | 
|  | : "r" ((u32) (a)),                                       \ | 
|  | "r" ((u32) (b)));} | 
|  |  | 
|  | #define __umulsidi3(u, v) \ | 
|  | ({DIunion __w;                                                        \ | 
|  | umul_ppmm (__w.s.high, __w.s.low, u, v);                            \ | 
|  | __w.ll; }) | 
|  |  | 
|  | s64 __muldi3(s64 u, s64 v) | 
|  | { | 
|  | DIunion w; | 
|  | DIunion uu, vv; | 
|  |  | 
|  | uu.ll = u, vv.ll = v; | 
|  |  | 
|  | w.ll = __umulsidi3(uu.s.low, vv.s.low); | 
|  | w.s.high += ((u32) uu.s.low * (u32) vv.s.high | 
|  | + (u32) uu.s.high * (u32) vv.s.low); | 
|  |  | 
|  | return w.ll; | 
|  | } |