Annotation of XNU/osfmk/kdp/ml/ppc/kdp_misc.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: #include <debug.h>
                     23: #include <ppc/asm.h>
                     24: #include <ppc/proc_reg.h>
                     25: #include <mach/ppc/vm_param.h>
                     26: #include <assym.s>
                     27: 
                     28: .set kLog2CacheLineSize, 5
                     29: .set kCacheLineSize, 32
                     30:  
                     31: ENTRY(kdp_flush_cache, TAG_NO_FRAME_USED)
                     32:        cmpi    cr0,0,r4,0                      /* is this zero length? */
                     33:        add     r4,r3,r4                        /* calculate last byte + 1 */
                     34:        subi    r4,r4,1                         /* calculate last byte */
                     35: 
                     36:        srwi    r5,r3,kLog2CacheLineSize        /* calc first cache line index */
                     37:        srwi    r4,r4,kLog2CacheLineSize        /* calc last cache line index */
                     38:        beq     cr0, LdataToCodeDone            /* done if zero length */
                     39: 
                     40:        subf    r4,r5,r4                        /* calc diff (# lines minus 1) */
                     41:        addi    r4,r4,1                         /* # of cache lines to flush */
                     42:        slwi    r5,r5,kLog2CacheLineSize        /* calc addr of first cache line */
                     43: 
                     44:        /* flush the data cache lines */
                     45:        mr      r3,r5                           /* starting address for loop */
                     46:        mtctr   r4                                      /* loop count */
                     47: LdataToCodeFlushLoop:
                     48:        dcbf    0, r3                                           /* flush the data cache line */
                     49:        addi    r3,r3,kCacheLineSize            /* advance to next cache line */
                     50:        bdnz    LdataToCodeFlushLoop            /* loop until count is zero */
                     51:        sync                                                            /* wait until RAM is valid */
                     52: 
                     53:        /* invalidate the code cache lines */
                     54:        mr      r3,r5                                           /* starting address for loop */
                     55:        mtctr   r4                                                      /* loop count */
                     56: LdataToCodeInvalidateLoop:
                     57:        icbi    0, r3                                           /* invalidate code cache line */
                     58:        addi    r3,r3,kCacheLineSize            /* advance to next cache line */
                     59:        bdnz    LdataToCodeInvalidateLoop       /* loop until count is zero */
                     60:        sync                                                            /* wait until last icbi completes */
                     61:        isync                                                           /* discard prefetched instructions */
                     62: LdataToCodeDone:
                     63:        blr                                                                     /* return nothing */
                     64: 
                     65: ENTRY(kdp_sync_cache, TAG_NO_FRAME_USED)
                     66:        sync                                    /* data sync */
                     67:        isync                                   /* inst sync */
                     68:        blr                                             /* return nothing */
                     69: 
                     70: ENTRY(kdp_xlate_off, TAG_NO_FRAME_USED)
                     71:        mfmsr   r3
                     72:        rlwinm  r4, r3, 0, MSR_DR_BIT+1, MSR_IR_BIT-1
                     73:        mtmsr   r4
                     74:        isync
                     75:        blr
                     76: 
                     77: ENTRY(kdp_xlate_restore, TAG_NO_FRAME_USED)
                     78:        mtmsr   r3
                     79:        isync
                     80:        blr
                     81: 

unix.superglobalmegacorp.com

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