###############################################################################
#
# Fast profiling interrupt handler
#
# Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
# Written by David Howells (dhowells@redhat.com)
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public Licence
# as published by the Free Software Foundation; either version
# 2 of the Licence, or (at your option) any later version.
#
###############################################################################
#include <linux/sys.h>
#include <linux/linkage.h>
#include <asm/segment.h>
#include <asm/smp.h>
#include <asm/intctl-regs.h>
#include <asm/timer-regs.h>

#define pi break

	.balign	4
counter:
	.long	-1

###############################################################################
#
# Profiling interrupt entry point
# - intended to run at interrupt priority 1
#
###############################################################################
ENTRY(profile_handler)
	movm	[d2,d3,a2],(sp)

	# ignore userspace
	mov	(12,sp),d2
	and	EPSW_nSL,d2
	bne	out

	# do nothing if there's no buffer
	mov	(prof_buffer),a2
	and	a2,a2
	beq	out
	or	0x20000000,a2

	# calculate relative position in text segment
	mov	(16,sp),d2
	sub	_stext,d2
	mov	(prof_shift),d3
	lsr	d3,d2
	mov	(prof_len),d3
	cmp	d3,d2
	bcc	outside_text

	# increment the appropriate profile bucket
do_inc:
	asl2	d2
	mov	(a2,d2),d3
	inc	d3
	mov	d3,(a2,d2)
out:
	mov	GxICR_DETECT,d2
	movbu	d2,(TM11ICR)		# ACK the interrupt
	movbu	(TM11ICR),d2
	movm	(sp),[d2,d3,a2]
	rti

outside_text:
	sub	1,d3
	mov	d3,d2
	bra	do_inc