xref: /titanic_50/usr/src/uts/sun4/ml/cpc_hwreg.s (revision 023e71de9e5670cebc23dd51162833661d3d2d3b)
17c478bd9Sstevel@tonic-gate/*
27c478bd9Sstevel@tonic-gate * CDDL HEADER START
37c478bd9Sstevel@tonic-gate *
47c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the
5*023e71deSHaik Aftandilian * Common Development and Distribution License (the "License").
6*023e71deSHaik Aftandilian * You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate *
87c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate * and limitations under the License.
127c478bd9Sstevel@tonic-gate *
137c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate *
197c478bd9Sstevel@tonic-gate * CDDL HEADER END
207c478bd9Sstevel@tonic-gate */
217c478bd9Sstevel@tonic-gate/*
22*023e71deSHaik Aftandilian * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
237c478bd9Sstevel@tonic-gate * Use is subject to license terms.
247c478bd9Sstevel@tonic-gate */
257c478bd9Sstevel@tonic-gate
267c478bd9Sstevel@tonic-gate/*
277c478bd9Sstevel@tonic-gate * Routines for manipulating the UltraSPARC performance
287c478bd9Sstevel@tonic-gate * counter registers (%pcr and %pic)
297c478bd9Sstevel@tonic-gate */
307c478bd9Sstevel@tonic-gate
317c478bd9Sstevel@tonic-gate#include <sys/asm_linkage.h>
327c478bd9Sstevel@tonic-gate
337c478bd9Sstevel@tonic-gate#if defined(lint) || defined(__lint)
347c478bd9Sstevel@tonic-gate
357c478bd9Sstevel@tonic-gate#include <sys/cpc_ultra.h>
367c478bd9Sstevel@tonic-gate
377c478bd9Sstevel@tonic-gate/*ARGSUSED*/
387c478bd9Sstevel@tonic-gatevoid
397c478bd9Sstevel@tonic-gateultra_setpcr(uint64_t pcr)
407c478bd9Sstevel@tonic-gate{}
417c478bd9Sstevel@tonic-gate
427c478bd9Sstevel@tonic-gate/*ARGSUSED*/
437c478bd9Sstevel@tonic-gateuint64_t
447c478bd9Sstevel@tonic-gateultra_getpcr(void)
457c478bd9Sstevel@tonic-gate{ return (0); }
467c478bd9Sstevel@tonic-gate
477c478bd9Sstevel@tonic-gate/*ARGSUSED*/
487c478bd9Sstevel@tonic-gatevoid
497c478bd9Sstevel@tonic-gateultra_setpic(uint64_t pic)
507c478bd9Sstevel@tonic-gate{}
517c478bd9Sstevel@tonic-gate
527c478bd9Sstevel@tonic-gateuint64_t
537c478bd9Sstevel@tonic-gateultra_getpic(void)
547c478bd9Sstevel@tonic-gate{ return (0); }
557c478bd9Sstevel@tonic-gate
567c478bd9Sstevel@tonic-gate#else	/* lint || __lint */
577c478bd9Sstevel@tonic-gate
587c478bd9Sstevel@tonic-gate	ENTRY(ultra_setpcr)
597c478bd9Sstevel@tonic-gate	retl
607c478bd9Sstevel@tonic-gate	wr	%o0, %pcr
617c478bd9Sstevel@tonic-gate	SET_SIZE(ultra_setpcr)
627c478bd9Sstevel@tonic-gate
637c478bd9Sstevel@tonic-gate	ENTRY(ultra_getpcr)
647c478bd9Sstevel@tonic-gate	retl
657c478bd9Sstevel@tonic-gate	rd	%pcr, %o0
667c478bd9Sstevel@tonic-gate	SET_SIZE(ultra_getpcr)
677c478bd9Sstevel@tonic-gate
687c478bd9Sstevel@tonic-gate	ENTRY(ultra_setpic)
697c478bd9Sstevel@tonic-gate#if defined(BB_ERRATA_1)	/* Writes to %pic may fail */
707c478bd9Sstevel@tonic-gate	ba	1f
717c478bd9Sstevel@tonic-gate	nop
727c478bd9Sstevel@tonic-gate	.align	16
737c478bd9Sstevel@tonic-gate1:	wr	%o0, %pic
747c478bd9Sstevel@tonic-gate	rd	%pic, %g0
757c478bd9Sstevel@tonic-gate	retl
767c478bd9Sstevel@tonic-gate	nop
777c478bd9Sstevel@tonic-gate#else
787c478bd9Sstevel@tonic-gate	retl
797c478bd9Sstevel@tonic-gate	wr	%o0, %pic
807c478bd9Sstevel@tonic-gate#endif	/* BB_ERRATA_1 */
817c478bd9Sstevel@tonic-gate	SET_SIZE(ultra_setpic)
827c478bd9Sstevel@tonic-gate
837c478bd9Sstevel@tonic-gate	ENTRY(ultra_getpic)
847c478bd9Sstevel@tonic-gate	retl
857c478bd9Sstevel@tonic-gate	rd	%pic, %o0
867c478bd9Sstevel@tonic-gate	SET_SIZE(ultra_getpic)
877c478bd9Sstevel@tonic-gate
887c478bd9Sstevel@tonic-gate#endif	/* lint || __lint */
89