| 1 | 
         207 | 
         jeremybenn | 
         /*
  | 
      
      
         | 2 | 
          | 
          | 
           Copyright 2007
  | 
      
      
         | 3 | 
          | 
          | 
           International Business Machines Corporation,
  | 
      
      
         | 4 | 
          | 
          | 
           Sony Computer Entertainment, Incorporated,
  | 
      
      
         | 5 | 
          | 
          | 
           Toshiba Corporation,
  | 
      
      
         | 6 | 
          | 
          | 
          
  | 
      
      
         | 7 | 
          | 
          | 
           All rights reserved.
  | 
      
      
         | 8 | 
          | 
          | 
          
  | 
      
      
         | 9 | 
          | 
          | 
           Redistribution and use in source and binary forms, with or without
  | 
      
      
         | 10 | 
          | 
          | 
           modification, are permitted provided that the following conditions are met:
  | 
      
      
         | 11 | 
          | 
          | 
          
  | 
      
      
         | 12 | 
          | 
          | 
             * Redistributions of source code must retain the above copyright notice,
  | 
      
      
         | 13 | 
          | 
          | 
           this list of conditions and the following disclaimer.
  | 
      
      
         | 14 | 
          | 
          | 
             * Redistributions in binary form must reproduce the above copyright
  | 
      
      
         | 15 | 
          | 
          | 
           notice, this list of conditions and the following disclaimer in the
  | 
      
      
         | 16 | 
          | 
          | 
           documentation and/or other materials provided with the distribution.
  | 
      
      
         | 17 | 
          | 
          | 
             * Neither the names of the copyright holders nor the names of their
  | 
      
      
         | 18 | 
          | 
          | 
           contributors may be used to endorse or promote products derived from
  | 
      
      
         | 19 | 
          | 
          | 
           this software without specific prior written permission.
  | 
      
      
         | 20 | 
          | 
          | 
          
  | 
      
      
         | 21 | 
          | 
          | 
           THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
  | 
      
      
         | 22 | 
          | 
          | 
           IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
  | 
      
      
         | 23 | 
          | 
          | 
           TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
  | 
      
      
         | 24 | 
          | 
          | 
           PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
  | 
      
      
         | 25 | 
          | 
          | 
           OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  | 
      
      
         | 26 | 
          | 
          | 
           EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  | 
      
      
         | 27 | 
          | 
          | 
           PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  | 
      
      
         | 28 | 
          | 
          | 
           PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
  | 
      
      
         | 29 | 
          | 
          | 
           LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  | 
      
      
         | 30 | 
          | 
          | 
           NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  | 
      
      
         | 31 | 
          | 
          | 
           SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  | 
      
      
         | 32 | 
          | 
          | 
         */
  | 
      
      
         | 33 | 
          | 
          | 
          
  | 
      
      
         | 34 | 
          | 
          | 
         #include <errno.h>
  | 
      
      
         | 35 | 
          | 
          | 
          
  | 
      
      
         | 36 | 
          | 
          | 
         /*
  | 
      
      
         | 37 | 
          | 
          | 
          * dom_chkd_less_than: "domain check double less than"
  | 
      
      
         | 38 | 
          | 
          | 
          *
  | 
      
      
         | 39 | 
          | 
          | 
          * Set errno to EDOM if vx < vc.
  | 
      
      
         | 40 | 
          | 
          | 
          *
  | 
      
      
         | 41 | 
          | 
          | 
          * This is for scalar use only, the input is a vector double, but both
  | 
      
      
         | 42 | 
          | 
          | 
          * values in both vectors must be the same.
  | 
      
      
         | 43 | 
          | 
          | 
          */
  | 
      
      
         | 44 | 
          | 
          | 
          
  | 
      
      
         | 45 | 
          | 
          | 
         static __inline void dom_chkd_less_than (vector double vx, vector double vc)
  | 
      
      
         | 46 | 
          | 
          | 
         {
  | 
      
      
         | 47 | 
          | 
          | 
           vector unsigned long long domain;
  | 
      
      
         | 48 | 
          | 
          | 
           vector signed int verrno;
  | 
      
      
         | 49 | 
          | 
          | 
           vector signed int fail = { EDOM, EDOM, EDOM, EDOM };
  | 
      
      
         | 50 | 
          | 
          | 
          
  | 
      
      
         | 51 | 
          | 
          | 
           domain = spu_cmpgt(vc, vx);
  | 
      
      
         | 52 | 
          | 
          | 
           verrno = spu_splats(errno);
  | 
      
      
         | 53 | 
          | 
          | 
           /*
  | 
      
      
         | 54 | 
          | 
          | 
            * domain is 2 long longs, but they have the same value. Even so, no
  | 
      
      
         | 55 | 
          | 
          | 
            * special code is needed to extract the scalar errno (we have all ones
  | 
      
      
         | 56 | 
          | 
          | 
            * or all zeroes for the preferred scalar slot).
  | 
      
      
         | 57 | 
          | 
          | 
            */
  | 
      
      
         | 58 | 
          | 
          | 
           errno = spu_extract(spu_sel(verrno, fail, (vector unsigned int) domain), 0);
  | 
      
      
         | 59 | 
          | 
          | 
         }
  |