3ecb7f4feb9a6ef17653fd7cbffaa199d7426b08
[fw/openocd] / src / target / mips_m4k.h
1 /***************************************************************************
2  *   Copyright (C) 2008 by Spencer Oliver                                  *
3  *   spen@spen-soft.co.uk                                                  *
4  *                                                                         *
5  *   Copyright (C) 2008 by David T.L. Wong                                 *
6  *                                                                         *
7  *   This program is free software; you can redistribute it and/or modify  *
8  *   it under the terms of the GNU General Public License as published by  *
9  *   the Free Software Foundation; either version 2 of the License, or     *
10  *   (at your option) any later version.                                   *
11  *                                                                         *
12  *   This program is distributed in the hope that it will be useful,       *
13  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
14  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
15  *   GNU General Public License for more details.                          *
16  *                                                                         *
17  *   You should have received a copy of the GNU General Public License     *
18  *   along with this program; if not, write to the                         *
19  *   Free Software Foundation, Inc.,                                       *
20  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
21  ***************************************************************************/
22
23 #ifndef MIPS_M4K_H
24 #define MIPS_M4K_H
25
26 #include "types.h"
27
28 struct target_s;
29
30 #define MIPSM4K_COMMON_MAGIC    0xB321B321
31
32 typedef struct mips_m4k_common_s
33 {
34         int common_magic;
35         mips32_common_t mips32_common;
36 } mips_m4k_common_t;
37
38 extern int mips_m4k_bulk_write_memory(struct target_s *target, u32 address, u32 count, u8 *buffer);
39
40 extern void mips_m4k_enable_breakpoints(struct target_s *target);
41 extern int mips_m4k_set_breakpoint(struct target_s *target, breakpoint_t *breakpoint);
42 extern int mips_m4k_unset_breakpoint(struct target_s *target, breakpoint_t *breakpoint);
43 extern int mips_m4k_add_breakpoint(struct target_s *target, breakpoint_t *breakpoint);
44 extern int mips_m4k_remove_breakpoint(struct target_s *target, breakpoint_t *breakpoint);
45 extern int mips_m4k_set_watchpoint(struct target_s *target, watchpoint_t *watchpoint);
46 extern int mips_m4k_unset_watchpoint(struct target_s *target, watchpoint_t *watchpoint);
47 extern int mips_m4k_add_watchpoint(struct target_s *target, watchpoint_t *watchpoint);
48 extern int mips_m4k_remove_watchpoint(struct target_s *target, watchpoint_t *watchpoint);
49 extern void mips_m4k_enable_watchpoints(struct target_s *target);
50
51 #endif  /*MIPS_M4K_H*/