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