142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * CDDL HEADER START
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * The contents of this file are subject to the terms of the
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Common Development and Distribution License (the "License").
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * You may not use this file except in compliance with the License.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * or http://www.opensolaris.org/os/licensing.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * See the License for the specific language governing permissions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * and limitations under the License.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * When distributing Covered Code, include this CDDL HEADER in each
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * If applicable, add the following below this CDDL HEADER, with the
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * fields enclosed by brackets "[]" replaced with your own identifying
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * information: Portions Copyright [yyyy] [name of copyright owner]
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * CDDL HEADER END
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Use is subject to license terms.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Assembly code support for the Cheetah+ module
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#pragma ident "%Z%%M% %I% %E% SMI"
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if !defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include "assym.h"
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/asm_linkage.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/mmu.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <vm/hat_sfmmu.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/machparam.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/machcpuvar.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/machthread.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/machtrap.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/privregs.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/asm_linkage.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/trap.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/cheetahregs.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/xc_impl.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/intreg.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/async.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/clock.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/cheetahasm.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/cmpregs.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#ifdef TRAPTRACE
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#include <sys/traptrace.h>
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* TRAPTRACE */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if !defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .global retire_l2_start
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .global retire_l2_end
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .global unretire_l2_start
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .global unretire_l2_end
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .global retire_l3_start
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .global retire_l3_end
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .global unretire_l3_start
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .global unretire_l3_end
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Panther version to reflush a line from both the L2 cache and L3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * cache by the respective indexes. Flushes all ways of the line from
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * each cache.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * l2_index Index into the L2$ of the line to be flushed. This
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * register will not be modified by this routine.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * l3_index Index into the L3$ of the line to be flushed. This
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * register will not be modified by this routine.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * scr2 scratch register.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * scr3 scratch register.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#define PN_ECACHE_REFLUSH_LINE(l2_index, l3_index, scr2, scr3) \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala set PN_L2_MAX_SET, scr2; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala set PN_L2_SET_SIZE, scr3; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1: \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [l2_index + scr2]ASI_L2_TAG, %g0; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp scr2, %g0; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bg,a 1b; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala sub scr2, scr3, scr2; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 6, scr2; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala6: \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp scr2, %g0; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bg,a 6b; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala sub scr2, 1, scr2; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala set PN_L3_MAX_SET, scr2; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala set PN_L3_SET_SIZE, scr3; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala2: \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [l3_index + scr2]ASI_EC_DIAG, %g0; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp scr2, %g0; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bg,a 2b; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala sub scr2, scr3, scr2;
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Panther version of ecache_flush_line. Flushes the line corresponding
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * to physaddr from both the L2 cache and the L3 cache.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * physaddr Input: Physical address to flush.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Output: Physical address to flush (preserved).
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * l2_idx_out Input: scratch register.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Output: Index into the L2$ of the line to be flushed.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * l3_idx_out Input: scratch register.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Output: Index into the L3$ of the line to be flushed.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * scr3 scratch register.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * scr4 scratch register.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala *
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#define PN_ECACHE_FLUSH_LINE(physaddr, l2_idx_out, l3_idx_out, scr3, scr4) \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala set PN_L3_SET_SIZE, l2_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala sub l2_idx_out, 1, l2_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and physaddr, l2_idx_out, l3_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala set PN_L3_IDX_DISP_FLUSH, l2_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala or l2_idx_out, l3_idx_out, l3_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala set PN_L2_SET_SIZE, l2_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala sub l2_idx_out, 1, l2_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and physaddr, l2_idx_out, l2_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala set PN_L2_IDX_DISP_FLUSH, scr3; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala or l2_idx_out, scr3, l2_idx_out; \
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_REFLUSH_LINE(l2_idx_out, l3_idx_out, scr3, scr4)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* !lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaint
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaretire_l2(uint64_t tag_addr, uint64_t pattern)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{return 0;}
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .align 4096
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(retire_l2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaretire_l2_start:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! since we disable interrupts, we don't need to do kpreempt_disable()
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rdpr %pstate, %o2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %o2, PSTATE_IE, %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %g1, %pstate ! disable interrupts
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Save current DCU state. Turn off IPS
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala setx DCU_IPS_MASK, %g2, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g0]ASI_DCU, %g1 ! save DCU in %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %g1, %o3, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g4, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g1, %o3, %o4) ! %g1 has DCU value
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5 ! assume success
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala8:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_FLUSH_LINE(%o0, %o3, %o4, %g2, %g3)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Check if line is invalid; if so, NA it.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%o0]ASI_L2_TAG, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala btst 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bnz %xcc, 2f
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala nop
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %o1, [%o0]ASI_L2_TAG
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala membar #Sync ! still on same cache line
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! now delay 15 cycles so we don't have hazard when we return
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 16, %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala brnz,pt %o1, 1b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala9:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! UNPARK-SIBLING_CORE is 7 instructions, so we cross a cache boundary
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g1, %o3, %o4) ! 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Restore the DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g1, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %o2, %pstate !restore pstate
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retl
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov %o5, %o0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala2:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! It is OK to have STATE as NA (if so, nothing to do!)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and %o3, 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o3, 0x5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala be,a,pt %xcc, 9b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 1, %o5 ! indicate was already NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Hmm. Not INV, not NA.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o5, 0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala be,a,pt %xcc, 8b ! Flush the cacheline again
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 2, %o5 ! indicate retry was done
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! We already Flushed cacheline second time. Return -1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ba 9b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaretire_l2_end:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(retire_l2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaint
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaunretire_l2(uint64_t tag_addr, uint64_t pattern)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{return 0;}
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(unretire_l2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaunretire_l2_start:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! since we disable interrupts, we don't need to do kpreempt_disable()
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rdpr %pstate, %o2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %o2, PSTATE_IE, %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %g1, %pstate ! disable interrupts
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Save current DCU state. Turn off IPS
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala setx DCU_IPS_MASK, %g2, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g0]ASI_DCU, %g1 ! save DCU in %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %g1, %o3, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g4, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0 /* flush required after changing the IC bit */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g1, %o3, %o4) ! %g1 has DCU value
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_FLUSH_LINE(%o0, %o3, %o4, %o5, %g2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5 ! assume success
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Check that line is in NA state; if so, INV it.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%o0]ASI_L2_TAG, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and %o3, 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o3, 0x5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bne,a,pt %xcc, 9f ! Wasn't NA, so something is wrong
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o5 ! indicate not NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g0, [%o0]ASI_L2_TAG
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala membar #Sync
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! now delay 15 cycles so we don't have hazard when we return
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 16, %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala brnz,pt %o1, 1b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala9:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! UNPARK-SIBLING_CORE is 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g1, %o3, %o4) ! 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Restore the DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g1, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %o2, %pstate !restore pstate
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retl
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov %o5, %o0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaunretire_l2_end:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(unretire_l2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaint
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaretire_l3(uint64_t tag_addr, uint64_t pattern)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{return 0;}
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(retire_l3)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaretire_l3_start:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! since we disable interrupts, we don't need to do kpreempt_disable()
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rdpr %pstate, %o2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %o2, PSTATE_IE, %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %g1, %pstate ! disable interrupts
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Save current DCU state. Turn off IPS
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala setx DCU_IPS_MASK, %g2, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g0]ASI_DCU, %g1 ! save DCU in %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %g1, %o3, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g4, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0 /* flush required after changing the IC bit */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g1, %o3, %o4) ! %g1 has DCU value
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! PN-ECACHE-FLUSH_LINE is 30 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_FLUSH_LINE(%o0, %o3, %o4, %o5, %g2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5 ! assume success
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Check if line is invalid; if so, NA it.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%o0]ASI_EC_DIAG, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala btst 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bnz %xcc, 2f
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala nop
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %o1, [%o0]ASI_EC_DIAG
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala membar #Sync ! still on same cache line
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! now delay 15 cycles so we don't have hazard when we return
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 16, %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala brnz,pt %o1, 1b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala9:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! UNPARK-SIBLING_CORE is 7 instructions, so we cross a cache boundary
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g1, %o3, %o4) ! 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Restore the DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g1, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %o2, %pstate !restore pstate
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retl
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov %o5, %o0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala2:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! It is OK to have STATE as NA (if so, nothing to do!)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and %o3, 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o3, 0x5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala be,a,pt %xcc, 9b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala inc %o5 ! indicate was already NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Hmm. Not INV, not NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ba 9b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaretire_l3_end:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(retire_l3)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaint
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaunretire_l3(uint64_t tag_addr, uint64_t pattern)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{return 0;}
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(unretire_l3)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaunretire_l3_start:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! since we disable interrupts, we don't need to do kpreempt_disable()
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rdpr %pstate, %o2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %o2, PSTATE_IE, %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %g1, %pstate ! disable interrupts
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Save current DCU state. Turn off IPS
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala setx DCU_IPS_MASK, %g2, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g0]ASI_DCU, %g1 ! save DCU in %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %g1, %o3, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g4, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0 /* flush required after changing the IC bit */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g1, %o3, %o4) ! %g1 has DCU value
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_FLUSH_LINE(%o0, %o3, %o4, %o5, %g2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5 ! assume success
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Check that line is in NA state; if so, INV it.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%o0]ASI_EC_DIAG, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and %o3, 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o3, 0x5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bne,a,pt %xcc, 9f ! Wasn't NA, so something is wrong
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o5 ! indicate not NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g0, [%o0]ASI_EC_DIAG
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala membar #Sync
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! now delay 15 cycles so we don't have hazard when we return
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 16, %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala brnz,pt %o1, 1b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala9:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! UNPARK-SIBLING_CORE is 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g1, %o3, %o4) ! 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Restore the DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g1, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %o2, %pstate !restore pstate
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retl
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov %o5, %o0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaunretire_l3_end:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(unretire_l3)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaint
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaretire_l2_alternate(uint64_t tag_addr, uint64_t pattern)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{return 0;}
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala .align 2048
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(retire_l2_alternate)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! since we disable interrupts, we don't need to do kpreempt_disable()
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rdpr %pstate, %o2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %o2, PSTATE_IE, %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %g1, %pstate ! disable interrupts
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Save current DCU state. Turn off IPS
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala setx DCU_IPS_MASK, %g2, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g0]ASI_DCU, %g1 ! save DCU in %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %g1, %o3, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g4, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g1, %o3, %o4) ! %g1 has DCU value
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5 ! assume success
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala8:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_FLUSH_LINE(%o0, %o3, %o4, %g2, %g3)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Check if line is invalid; if so, NA it.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%o0]ASI_L2_TAG, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala btst 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bnz %xcc, 2f
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala nop
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %o1, [%o0]ASI_L2_TAG
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala membar #Sync ! still on same cache line
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! now delay 15 cycles so we don't have hazard when we return
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 16, %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala brnz,pt %o1, 1b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala9:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! UNPARK-SIBLING_CORE is 7 instructions, so we cross a cache boundary
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g1, %o3, %o4) ! 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Restore the DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g1, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %o2, %pstate !restore pstate
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retl
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov %o5, %o0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala2:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! It is OK to have STATE as NA (if so, nothing to do!)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and %o3, 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o3, 0x5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala be,a,pt %xcc, 9b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 1, %o5 ! indicate was already NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Hmm. Not INV, not NA.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o5, 0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala be,a,pt %xcc, 8b ! Flush the cacheline again
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 2, %o5 ! indicate retry was done
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! We already Flushed cacheline second time. Return -1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ba 9b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(retire_l2_alternate)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaint
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaunretire_l2_alternate(uint64_t tag_addr, uint64_t pattern)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{return 0;}
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(unretire_l2_alternate)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! since we disable interrupts, we don't need to do kpreempt_disable()
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rdpr %pstate, %o2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %o2, PSTATE_IE, %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %g1, %pstate ! disable interrupts
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Save current DCU state. Turn off IPS
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala setx DCU_IPS_MASK, %g2, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g0]ASI_DCU, %g1 ! save DCU in %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %g1, %o3, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g4, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0 /* flush required after changing the IC bit */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g1, %o3, %o4) ! %g1 has DCU value
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_FLUSH_LINE(%o0, %o3, %o4, %o5, %g2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5 ! assume success
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Check that line is in NA state; if so, INV it.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%o0]ASI_L2_TAG, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and %o3, 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o3, 0x5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bne,a,pt %xcc, 9f ! Wasn't NA, so something is wrong
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o5 ! indicate not NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g0, [%o0]ASI_L2_TAG
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala membar #Sync
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! now delay 15 cycles so we don't have hazard when we return
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 16, %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala brnz,pt %o1, 1b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala9:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! UNPARK-SIBLING_CORE is 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g1, %o3, %o4) ! 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Restore the DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g1, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %o2, %pstate !restore pstate
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retl
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov %o5, %o0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(unretire_l2_alternate)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaint
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaretire_l3_alternate(uint64_t tag_addr, uint64_t pattern)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{return 0;}
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(retire_l3_alternate)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! since we disable interrupts, we don't need to do kpreempt_disable()
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rdpr %pstate, %o2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %o2, PSTATE_IE, %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %g1, %pstate ! disable interrupts
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Save current DCU state. Turn off IPS
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala setx DCU_IPS_MASK, %g2, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g0]ASI_DCU, %g1 ! save DCU in %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %g1, %o3, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g4, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0 /* flush required after changing the IC bit */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g1, %o3, %o4) ! %g1 has DCU value
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! PN-ECACHE-FLUSH_LINE is 30 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_FLUSH_LINE(%o0, %o3, %o4, %o5, %g2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5 ! assume success
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Check if line is invalid; if so, NA it.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%o0]ASI_EC_DIAG, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala btst 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bnz %xcc, 2f
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala nop
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %o1, [%o0]ASI_EC_DIAG
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala membar #Sync ! still on same cache line
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! now delay 15 cycles so we don't have hazard when we return
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 16, %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala brnz,pt %o1, 1b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala9:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! UNPARK-SIBLING_CORE is 7 instructions, so we cross a cache boundary
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g1, %o3, %o4) ! 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Restore the DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g1, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %o2, %pstate !restore pstate
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retl
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov %o5, %o0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala2:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! It is OK to have STATE as NA (if so, nothing to do!)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and %o3, 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o3, 0x5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala be,a,pt %xcc, 9b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala inc %o5 ! indicate was already NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Hmm. Not INV, not NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ba 9b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(retire_l3_alternate)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaint
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaunretire_l3_alternate(uint64_t tag_addr, uint64_t pattern)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{return 0;}
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(unretire_l3_alternate)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! since we disable interrupts, we don't need to do kpreempt_disable()
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rdpr %pstate, %o2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %o2, PSTATE_IE, %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %g1, %pstate ! disable interrupts
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Save current DCU state. Turn off IPS
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala setx DCU_IPS_MASK, %g2, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g0]ASI_DCU, %g1 ! save DCU in %g1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala andn %g1, %o3, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g4, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0 /* flush required after changing the IC bit */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g1, %o3, %o4) ! %g1 has DCU value
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PN_ECACHE_FLUSH_LINE(%o0, %o3, %o4, %o5, %g2)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala clr %o5 ! assume success
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! Check that line is in NA state; if so, INV it.
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%o0]ASI_EC_DIAG, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala and %o3, 0x7, %o3
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala cmp %o3, 0x5
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala bne,a,pt %xcc, 9f ! Wasn't NA, so something is wrong
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o5 ! indicate not NA
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g0, [%o0]ASI_EC_DIAG
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala membar #Sync
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! now delay 15 cycles so we don't have hazard when we return
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov 16, %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala1:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala brnz,pt %o1, 1b
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala dec %o1
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala9:
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ! UNPARK-SIBLING_CORE is 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g1, %o3, %o4) ! 7 instructions
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Restore the DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stxa %g1, [%g0]ASI_DCU
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala flush %g0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wrpr %g0, %o2, %pstate !restore pstate
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retl
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala mov %o5, %o0
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(unretire_l3_alternate)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalavoid
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaget_ecache_dtags_tl1(uint64_t afar, ch_cpu_logout_t *clop)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{ }
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(get_ecache_dtags_tl1)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala PARK_SIBLING_CORE(%g3, %g4, %g5)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala add %g2, CH_CLO_DATA + CH_CHD_EC_DATA, %g2
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala rd %asi, %g4
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wr %g0, ASI_N, %asi
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala GET_ECACHE_DTAGS(%g1, %g2, %g5, %g6, %g7)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala wr %g4, %asi
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala UNPARK_SIBLING_CORE(%g3, %g4, %g5) ! can use %g3 again
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retry
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(get_ecache_dtags_tl1)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalavoid
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaget_l2_tag_tl1(uint64_t tag_addr, uint64_t tag_data_ptr)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{ }
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(get_l2_tag_tl1)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Now read the tag data
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g1]ASI_L2_TAG, %g4 ! save tag_data
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stx %g4, [%g2]
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retry
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(get_l2_tag_tl1)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#if defined(lint)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala/*ARGSUSED*/
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalavoid
142c9f13e148d687426ed2d4e8bd93717eeaebbcbalaget_l3_tag_tl1(uint64_t tag_addr, uint64_t tag_data_ptr)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala{ }
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#else
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ENTRY(get_l3_tag_tl1)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala /*
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala * Now read the tag data
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala ldxa [%g1]ASI_EC_DIAG, %g4 ! save tag_data
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala stx %g4, [%g2]
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala retry
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala SET_SIZE(get_l3_tag_tl1)
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala#endif /* lint */
142c9f13e148d687426ed2d4e8bd93717eeaebbcbala