123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- /*
- * init_tlb.S
- *
- * Common TLB initialization for MIPS cores
- */
- /*
- Copyright (c) 2007-2018, MIPS Tech, LLC and/or its affiliated group companies or licensors
- All rights reserved.
- Redistribution and use in source and binary forms, with or without modification, are
- permitted provided that the following conditions are met:
- 1. Redistributions of source code must retain the above copyright notice, this list of
- conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright notice, this list
- of conditions and the following disclaimer in the documentation and/or other materials
- provided with the distribution.
- 3. Neither the name of the copyright holder nor the names of its contributors may be
- used to endorse or promote products derived from this software without specific prior
- written permission.
- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
- EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
- SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
- OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
- OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
- #include <mips/asm.h>
- #include <core_config.h>
- #include <mips/regdef.h>
- #include <mips/m32c0.h>
- /**************************************************************************************
- **************************************************************************************/
- LEAF(init_tlb)
- check_for_tlb:
- // Determine if we have a TLB
- mfc0 a0, C0_CONFIG // read C0_Config
- ext a0, a0, 7, 3 // extract MT field
- li a2, 0x1 // load a 1 to check against
- bne a0, a2, done_init_tlb
- mfc0 a1, C0_CONFIG1 // C0_Config1
- start_init_tlb:
- // Config1MMUSize == Number of TLB entries - 1
- ext a0, a1, CFG1_MMUSSHIFT, 6 // extract MMU Size
- mtc0 zero, C0_ENTRYLO0 // write C0_EntryLo0
- mtc0 zero, C0_ENTRYLO1 // write C0_EntryLo1
- mtc0 zero, C0_PAGEMASK // write C0_PageMask
- mtc0 zero, C0_WIRED // write C0_Wired
- li a3, 0x80000000
- next_tlb_entry_pair:
- mtc0 a0, C0_INDEX // write C0_Index
- mtc0 a3, C0_ENTRYHI // write C0_EntryHi
- ehb
- tlbwi
- add a3, 0x2000 // Add 8K to the address to avoid TLB conflict with previous entry
- add a0, -1
- bgez a0, next_tlb_entry_pair
- done_init_tlb:
- jr ra
- END(init_tlb)
|