aboutsummaryrefslogtreecommitdiff
path: root/arch/mn10300/kernel/gdb-low.S
blob: e2725552cd82afd9b07de67e21ecf5890cb1850e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
###############################################################################
#
# 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