Annotation of XNU/osfmk/ppc/AltiAssist.s, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
                      3:  *
                      4:  * @APPLE_LICENSE_HEADER_START@
                      5:  * 
                      6:  * The contents of this file constitute Original Code as defined in and
                      7:  * are subject to the Apple Public Source License Version 1.1 (the
                      8:  * "License").  You may not use this file except in compliance with the
                      9:  * License.  Please obtain a copy of the License at
                     10:  * http://www.apple.com/publicsource and read it before using this file.
                     11:  * 
                     12:  * This Original Code and all software distributed under the License are
                     13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
                     14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
                     15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
                     16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
                     17:  * License for the specific language governing rights and limitations
                     18:  * under the License.
                     19:  * 
                     20:  * @APPLE_LICENSE_HEADER_END@
                     21:  */
                     22: /*                                                                                                                                                                                     
                     23:        AltiAssist.s 
                     24: 
                     25:        Do the VMX assists
                     26: 
                     27:        Lovingly crafted by Bill Angell using traditional methods and only natural or recycled materials.
                     28:        No animal products are used other than rendered otter bile and deep fried pork lard.
                     29: 
                     30: */
                     31: 
                     32: #include <cpus.h>
                     33: #include <ppc/asm.h>
                     34: #include <ppc/proc_reg.h>
                     35: #include <ppc/exception.h>
                     36: #include <mach/machine/vm_param.h>
                     37: #include <assym.s>
                     38: 
                     39: ;
                     40: ;                      NOTE:   This is temporary!!!  Java mode is disabled until full
                     41: ;                                      testing can be completed!!!!  This file contains no protected
                     42: ;                                      source.
                     43: ;
                     44: ;                      General stuff what happens here:
                     45: ;                              1)      All general context saved, interrupts off, translation off
                     46: ;                              2)      Vector and floating point disabled, but there may be live context.
                     47: ;                                      This code is responsible for saving and restoring what is used. This
                     48: ;                                      includes exception states, java mode, etc.
                     49: ;                              3)      No attempt is made to resolve page faults.  PTE misses are handled
                     50: ;                                      automatically, but actual faults (ala copyin/copyout) are not. If 
                     51: ;                                      a fault does occur, the exception that caused entry to the emulation
                     52: ;                                      routine is remapped to either an instruction or data miss (depending
                     53: ;                                      upon the stage detected) and redriven through the exception handler.
                     54: ;                                      The only time that an instruction fault can happen is when a different
                     55: ;                                      processor removes a mapping between our original fault and when we
                     56: ;                                      fetch the assisted instruction. For an assisted instruction, data
                     57: ;                                      faults should not occur (except in the MP case).  For a purely
                     58: ;                                      emulated instruction, faults can occur.
                     59: ;
                     60: ;                      Emulation algorithms cloned from MacOS 8 code.
                     61: ;
                     62: ;                      Assumes that R2 = per_proc_area
                     63: ;
                     64: ;
                     65: 
                     66: 
                     67: #define DISABLEJAVA 1
                     68: 
                     69: 
                     70:                        .align  5
                     71:                        .globl  EXT(AltivecAssist)
                     72: 
                     73: LEXT(AltivecAssist)
                     74: 
                     75: #if DISABLEJAVA
                     76:                        mfmsr           r20                                                     ; Get the current MSR
                     77:                        li                      r10,emvr0                                       ; Point to the vector savearea
                     78:                        oris            r20,r20,hi16(MASK(MSR_VEC))     ; Turn on vector
                     79:                        mtmsr           r20                                                     ; Turn on vector
                     80:                        isync
                     81:                        
                     82:                        li                      r11,emvr1                                       ; Another savearea
                     83:                        stvxl           v0,r10,r2                                       ; Save V0
                     84:                        stvxl           v1,r11,r2                                       ; Save V1
                     85:                        vspltisw        v0,1                                            ; Set a 1 in V0                 
                     86:                        vspltisw        v1,8                                            ; Get half of the shift
                     87:                        vslw            v0,v0,v1                                        ; Shift half way
                     88:                        vslw            v0,v0,v1                                        ; Shift the rest of the way (we now have 0x00010000)
                     89:                        mfvscr          v1                                                      ; Get the VSCR
                     90:                        vor                     v1,v1,v0                                        ; Turn off Java mode
                     91:                        lvxl            v0,r10,r2                                       ; Restore V0
                     92:                        mtvscr          v1                                                      ; Set Java mode off
                     93:                        lvxl            v1,r11,r2                                       ; Restore V1
                     94:                        
                     95:                        li                      r11,T_IN_VAIN                           ; We are all done
                     96:                        b                       EXT(EmulExit)                           ; Go away...
                     97: 
                     98: #else
                     99:                        BREAKPOINT_TRAP
                    100: #endif
                    101: 
                    102: 
                    103: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.