123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- ###############################################################################
- #
- # 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
|