Ensure Cortex-M reset wakes device from sleep (wfi/wfe)
[fw/openocd] / src / target / etb.h
index 12e613ffc3659f658690b0b01d21a05f41aceb08..0ac6413f5c891575c6d9442176f6f8c87bd6062a 100644 (file)
@@ -1,69 +1,60 @@
-/***************************************************************************\r
- *   Copyright (C) 2007 by Dominic Rath                                    *\r
- *   Dominic.Rath@gmx.de                                                   *\r
- *                                                                         *\r
- *   This program is free software; you can redistribute it and/or modify  *\r
- *   it under the terms of the GNU General Public License as published by  *\r
- *   the Free Software Foundation; either version 2 of the License, or     *\r
- *   (at your option) any later version.                                   *\r
- *                                                                         *\r
- *   This program is distributed in the hope that it will be useful,       *\r
- *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *\r
- *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *\r
- *   GNU General Public License for more details.                          *\r
- *                                                                         *\r
- *   You should have received a copy of the GNU General Public License     *\r
- *   along with this program; if not, write to the                         *\r
- *   Free Software Foundation, Inc.,                                       *\r
- *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *\r
- ***************************************************************************/\r
-#ifndef ETB_H\r
-#define ETB_H\r
-\r
-#include "command.h"\r
-#include "target.h"\r
-#include "register.h"\r
-#include "arm_jtag.h"\r
-\r
-/* ETB registers */\r
-enum\r
-{\r
-    ETB_ID = 0x00,\r
-    ETB_RAM_DEPTH = 0x01,\r
-    ETB_RAM_WIDTH = 0x02,\r
-    ETB_STATUS = 0x03,\r
-    ETB_RAM_DATA = 0x04,\r
-    ETB_RAM_READ_POINTER = 0x05,\r
-    ETB_RAM_WRITE_POINTER = 0x06,\r
-    ETB_TRIGGER_COUNTER = 0x07,\r
-    ETB_CTRL = 0x08,\r
-};\r
-\r
-typedef struct etb_s\r
-{\r
-       int chain_pos;\r
-       int cur_scan_chain;\r
-       reg_cache_t *reg_cache;\r
-       \r
-       /* ETB parameters */\r
-       int RAM_depth;\r
-       int RAM_width;\r
-} etb_t;\r
-\r
-typedef struct etb_reg_s\r
-{\r
-       int addr;\r
-       etb_t *etb;\r
-} etb_reg_t;\r
-\r
-extern reg_cache_t* etb_build_reg_cache(etb_t *etb);\r
-extern int etb_read_reg(reg_t *reg);\r
-extern int etb_write_reg(reg_t *reg, u32 value);\r
-extern int etb_read_reg_w_check(reg_t *reg, u8* check_value, u8* check_mask);\r
-extern int etb_store_reg(reg_t *reg);\r
-extern int etb_set_reg(reg_t *reg, u32 value);\r
-extern int etb_set_reg_w_exec(reg_t *reg, u8 *buf);\r
-\r
-extern int etb_register_commands(struct command_context_s *cmd_ctx, command_t *arm7_9_cmd);\r
-\r
-#endif /* ETB_H */\r
+/***************************************************************************
+ *   Copyright (C) 2007 by Dominic Rath                                    *
+ *   Dominic.Rath@gmx.de                                                   *
+ *                                                                         *
+ *   This program is free software; you can redistribute it and/or modify  *
+ *   it under the terms of the GNU General Public License as published by  *
+ *   the Free Software Foundation; either version 2 of the License, or     *
+ *   (at your option) any later version.                                   *
+ *                                                                         *
+ *   This program is distributed in the hope that it will be useful,       *
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
+ *   GNU General Public License for more details.                          *
+ *                                                                         *
+ *   You should have received a copy of the GNU General Public License     *
+ *   along with this program; if not, write to the                         *
+ *   Free Software Foundation, Inc.,                                       *
+ *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
+ ***************************************************************************/
+
+#ifndef ETB_H
+#define ETB_H
+
+/* ETB registers */
+enum {
+       ETB_ID = 0x00,
+       ETB_RAM_DEPTH = 0x01,
+       ETB_RAM_WIDTH = 0x02,
+       ETB_STATUS = 0x03,
+       ETB_RAM_DATA = 0x04,
+       ETB_RAM_READ_POINTER = 0x05,
+       ETB_RAM_WRITE_POINTER = 0x06,
+       ETB_TRIGGER_COUNTER = 0x07,
+       ETB_CTRL = 0x08,
+};
+
+struct etb {
+       struct etm_context *etm_ctx;
+       struct jtag_tap *tap;
+       uint32_t cur_scan_chain;
+       struct reg_cache *reg_cache;
+
+       /* ETB parameters */
+       uint32_t ram_depth;
+       uint32_t ram_width;
+
+       /** how much trace buffer to fill after trigger */
+       unsigned trigger_percent;
+};
+
+struct etb_reg {
+       uint32_t addr;
+       struct etb *etb;
+};
+
+extern struct etm_capture_driver etb_capture_driver;
+
+struct reg_cache *etb_build_reg_cache(struct etb *etb);
+
+#endif /* ETB_H */