116 строки
2.8 KiB
ArmAsm
116 строки
2.8 KiB
ArmAsm
###############################################################################
|
|
#
|
|
# MN10300 Low-level gdbstub routines
|
|
#
|
|
# 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/smp.h>
|
|
#include <asm/cache.h>
|
|
#include <asm/cpu-regs.h>
|
|
#include <asm/exceptions.h>
|
|
#include <asm/frame.inc>
|
|
#include <asm/serial-regs.h>
|
|
|
|
.text
|
|
|
|
###############################################################################
|
|
#
|
|
# GDB stub read memory with guard
|
|
# - D0 holds the memory address to read
|
|
# - D1 holds the address to store the byte into
|
|
#
|
|
###############################################################################
|
|
.globl gdbstub_read_byte_guard
|
|
.globl gdbstub_read_byte_cont
|
|
ENTRY(gdbstub_read_byte)
|
|
mov d0,a0
|
|
mov d1,a1
|
|
clr d0
|
|
gdbstub_read_byte_guard:
|
|
movbu (a0),d1
|
|
gdbstub_read_byte_cont:
|
|
movbu d1,(a1)
|
|
ret [],0
|
|
|
|
.globl gdbstub_read_word_guard
|
|
.globl gdbstub_read_word_cont
|
|
ENTRY(gdbstub_read_word)
|
|
mov d0,a0
|
|
mov d1,a1
|
|
clr d0
|
|
gdbstub_read_word_guard:
|
|
movhu (a0),d1
|
|
gdbstub_read_word_cont:
|
|
movhu d1,(a1)
|
|
ret [],0
|
|
|
|
.globl gdbstub_read_dword_guard
|
|
.globl gdbstub_read_dword_cont
|
|
ENTRY(gdbstub_read_dword)
|
|
mov d0,a0
|
|
mov d1,a1
|
|
clr d0
|
|
gdbstub_read_dword_guard:
|
|
mov (a0),d1
|
|
gdbstub_read_dword_cont:
|
|
mov d1,(a1)
|
|
ret [],0
|
|
|
|
###############################################################################
|
|
#
|
|
# GDB stub write memory with guard
|
|
# - D0 holds the byte to store
|
|
# - D1 holds the memory address to write
|
|
#
|
|
###############################################################################
|
|
.globl gdbstub_write_byte_guard
|
|
.globl gdbstub_write_byte_cont
|
|
ENTRY(gdbstub_write_byte)
|
|
mov d0,a0
|
|
mov d1,a1
|
|
clr d0
|
|
gdbstub_write_byte_guard:
|
|
movbu a0,(a1)
|
|
gdbstub_write_byte_cont:
|
|
ret [],0
|
|
|
|
.globl gdbstub_write_word_guard
|
|
.globl gdbstub_write_word_cont
|
|
ENTRY(gdbstub_write_word)
|
|
mov d0,a0
|
|
mov d1,a1
|
|
clr d0
|
|
gdbstub_write_word_guard:
|
|
movhu a0,(a1)
|
|
gdbstub_write_word_cont:
|
|
ret [],0
|
|
|
|
.globl gdbstub_write_dword_guard
|
|
.globl gdbstub_write_dword_cont
|
|
ENTRY(gdbstub_write_dword)
|
|
mov d0,a0
|
|
mov d1,a1
|
|
clr d0
|
|
gdbstub_write_dword_guard:
|
|
mov a0,(a1)
|
|
gdbstub_write_dword_cont:
|
|
ret [],0
|
|
|
|
###############################################################################
|
|
#
|
|
# GDB stub BUG() trap
|
|
#
|
|
###############################################################################
|
|
ENTRY(__gdbstub_bug_trap)
|
|
.byte 0xF7,0xF7 # don't use 0xFF as the JTAG unit preempts that
|
|
ret [],0
|