博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Programming internal SRAM over SWD
阅读量:6039 次
发布时间:2019-06-20

本文共 52476 字,大约阅读时间需要 174 分钟。

//// Copyright (c) 2013 SILICON LABORATORIES, INC.//// FILE NAME    : 32bit_prog_defs.h// DESCRIPTION  : ARM Serial Wire debug interface header file//#ifndef _32BIT_PROG_DEFS_#define _32BIT_PROG_DEFS_#include 
#include
//-----------------------------------------------------------------------------// Project Constants//-----------------------------------------------------------------------------// System clock frequency in Hz#define SYSCLK 48000000#define BOOL bit#define TRUE (1 == 1)#define FALSE (!TRUE)// Delay Times#define DELAY100mS -( SYSCLK / 48 * 0.1 )#define DELAY20mS -( SYSCLK / 48 * 0.02 )#define DELAY5mS -( SYSCLK / 48 * 0.005 )#define DELAY1mS -( SYSCLK / 48 * 0.001 )#define DELAY100uS -( SYSCLK / 48 * 0.000100 )#define DELAY75uS -( SYSCLK / 48 * 0.000075 )#define DELAY25uS -( SYSCLK / 48 * 0.000025 )#define DELAY10uS -( SYSCLK / 48 * 0.00001 )#define DELAY4_3uS -( SYSCLK / 48 * 0.0000043 )#define DELAY3uS -( SYSCLK / 48 * 0.000003 )#define DELAY2uS -( SYSCLK / 48 * 0.000002 )// Timeout Times#define TIMEOUT_2Sec -( SYSCLK / 48 * 2 )// Command Status Response Codes#define HOST_COMMAND_OK 0x55#define HOST_INVALID_COMMAND 0x80#define HOST_COMMAND_FAILED 0x81#define HOST_AP_TIMEOUT 0x82#define HOST_WIRE_ERROR 0x83#define HOST_ACK_FAULT 0x84#define HOST_DP_NOT_CONNECTED 0x85// Property SRST values#define SRST_ASSERTED 0x1#define SRST_DEASSERTED 0x0#define DAP_RETRY_COUNT 255//-----------------------------------------------------------------------------// ARM Debug Interface Constants//-----------------------------------------------------------------------------// ARM CoreSight SWD-DP packet request values#define SW_IDCODE_RD 0xA5#define SW_ABORT_WR 0x81#define SW_CTRLSTAT_RD 0x8D#define SW_CTRLSTAT_WR 0xA9#define SW_RESEND_RD 0x95#define SW_SELECT_WR 0xB1#define SW_RDBUFF_RD 0xBD// ARM CoreSight SW-DP packet request masks#define SW_REQ_PARK_START 0x81#define SW_REQ_PARITY 0x20#define SW_REQ_A32 0x18#define SW_REQ_RnW 0x04#define SW_REQ_APnDP 0x02// ARM CoreSight SW-DP packet acknowledge values#define SW_ACK_OK 0x1#define SW_ACK_WAIT 0x2#define SW_ACK_FAULT 0x4#define SW_ACK_PARITY_ERR 0x8// ARM CoreSight DAP command values#define DAP_IDCODE_RD 0x02#define DAP_ABORT_WR 0x00#define DAP_CTRLSTAT_RD 0x06#define DAP_CTRLSTAT_WR 0x04#define DAP_SELECT_WR 0x08#define DAP_RDBUFF_RD 0x0E// ARM CoreSight DAP command masks#define DAP_CMD_PACKED 0x80#define DAP_CMD_A32 0x0C#define DAP_CMD_RnW 0x02#define DAP_CMD_APnDP 0x01#define DAP_CMD_MASK 0x0F//-----------------------------------------------------------------------------// Global Variables//-----------------------------------------------------------------------------// These pin assignments match the debug adapter cable//// Pin 1: VREF P1.0// Pin 2: SWDIO/TMS P1.1// Pin 3: ground P1.2// Pin 4: SWCLK/TCK P1.3// Pin 5: ground P1.4// Pin 6: SWO/TDO P1.5// Pin 7: NC P1.6// Pin 8: TDI P1.7// Pin 9: ground GND// Pin 10: RESETB P2.1// LED Pin DefinitionsSBIT(LED0, SFR_P2, 2); // Green LEDSBIT(LED1, SFR_P2, 3); // Green LED// JTAG Pin DefinitionsSBIT(TDO_In, SFR_P1, 5); // TDO InputSBIT(TDI_Out, SFR_P1, 7); // TDI OutputSBIT(TMS_Out, SFR_P1, 1); // TMS OutputSBIT(TCK_Out, SFR_P1, 3); // TCK Output// Serial Wire Pin DefinitionsSBIT(SWDIO_Out, SFR_P1, 1); // SWDIO OutputSBIT(SWDIO_In, SFR_P1, 1); // SWDIO InputSBIT(SWCLK_Out, SFR_P1, 3); // SWCLK Output// SWO on P0.5 with TDO// Reset Pin DefinitionsSBIT(nSRST_Out, SFR_P0, 1); // nSRST OutputSBIT(nSRST_In, SFR_P0, 1); // nSRST Input// These pins are ground on the CoreSight debug connectorSBIT(P1_2, SFR_P1, 2);SBIT(P1_4, SFR_P1, 4);//-----------------------------------------------------------------------------// Macros//-----------------------------------------------------------------------------// Serial Wire Interface Macros#define _SetSWPinsIdle { P1MDOUT |= 0x08; P1MDOUT &= ~0x22; P1 |= 0x2A; }#define _SetSWDIOasInput { P1MDOUT &= ~0x02; P1 |= 0x02; }#define _SetSWDIOasOutput P1MDOUT |= 0x02// Set all debug pins xPIN_OUT to 1 (open drain outputs off)#define _ResetDebugPins { P1MDOUT &= ~0x8A; P1 |= 0x8A; P0MDOUT &= ~0x02; P0 |= 0x02; }// Target Reset Control Macros#define _AssertTargetReset nSRST_Out = 0#define _ReleaseTargetReset nSRST_Out = 1#define _IsTargetReset (nSRST_In == 1)//-----------------------------------------------------------------------------// Function Prototypes//-----------------------------------------------------------------------------typedef unsigned char STATUS;//-----------------------------------------------------------------------------// SWD-DP Interface Functions//-----------------------------------------------------------------------------void SWD_Initialize (void);STATUS SWD_Configure (U8 dp_type);STATUS SWD_Connect (void);STATUS SWD_Disconnect (void);STATUS SWD_LineReset (void);STATUS SWD_ClearErrors (void);STATUS SWD_DAP_Move(U8, U8, U32 *);STATUS SW_Response (U8);void SW_DAP_Read(U8, U8, U32 *);void SW_DAP_Write(U8, U8, U32 *, BOOL);U8 SW_Request(U8);BOOL SW_CalcDataParity(void);U8 SW_ShiftPacket(U8, U8);void SW_ShiftByteOut(U8);U8 SW_ShiftByteIn(void);void SW_ShiftReset(void);#endif // _32BIT_PROG_DEFS

 

U32 code binraw0[ ] ={ 0x20008000, 0x2000016f, 0x20000185, 0x20000187, 0x20000189, 0x20000189,  0x20000189, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x20000189,  0x20000189, 0x00000000, 0x20000189, 0x20000041, 0x13f8f240, 0x300f2c2,  0x1c426818, 0x4770601a, 0x7f0e92d, 0xf2c42500, 0xf04f0503, 0xf8c50aa5,  0xf44fa030, 0xf24a4950, 0xf44f1240, 0xf24a4420, 0xf04f13e0, 0xf8c50add,  0xf2c4a030, 0xf2c40302, 0xf44f0202, 0xf04f7040, 0xf04f4c00, 0xf2c40808,  0xf44f0402, 0x26036740, 0x902f2c4, 0x11f4f240, 0xf8c92502, 0xf2c25024,  0xf8c20100, 0xf8c28044, 0xf8c48024, 0xf8c4c044, 0x6498c034, 0x62586058,  0x625f645f, 0x62566456, 0xf644680a, 0xf2c15cd3, 0xfbac0c62, 0xf24e2102,  0x9880310, 0x300f2ce, 0xf44f3801, 0x6058426d, 0x200f2ce, 0x200021f0,  0x1023f882, 0x20076098, 0xf8826018, 0xe8bd1023, 0x477007f0, 0xf24ab410,  0xf24a1040, 0x4a0c14e0, 0x402f2c4, 0x2f2c4, 0xf5016811, 0x6813717a,  0xd8fc4299, 0x43cb6821, 0xf041b299, 0x60e36340, 0x43cb6801, 0xfc83fa1f,  0x3140f44c, 0xe7eb60c1, 0x200001f8, 0x49112000, 0xf8504a11, 0xf8413b04,  0x42913b04, 0x2000dbf9, 0xf8414a0e, 0x42910b04, 0x480ddbfb, 0x60014909,  0x5e00f04e, 0xf0004770, 0xf7fff817, 0x4809ffc7, 0x60084907, 0x468d6801,  0x47006840, 0xe7fee7fe, 0xe7fe, 0x20000000, 0x200001f8, 0x200001fc,  0xe000ed08, 0x1000, 0x360f24d, 0x302f2c4, 0x7d0691a, 0x6918d51f, 0xd41c0781,  0xf013691b, 0xd1180204, 0xc10f24e, 0xc00f2ce, 0x120f44f, 0x1004f8cc,  0x2008f8cc, 0x46612205, 0x2000f8cc, 0xf24e6808, 0x3c20310, 0x300f2ce,  0x2200d5f8, 0x605a601a, 0xf7ff609a, 0xbf00bf2f, 0x1312d00,};U32 code binraw[ ] ={ 0x20008000, 0x20000151, 0x20000d8d, 0x20000d91, 0x20000d95, 0x20000d99,  0x20000d9d, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x20000141,  0x20000145, 0x00000000, 0x20000149, 0x20000d7d, 0x20000219, 0x20000219,  0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219,  0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219,  0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219,  0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219,  0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219,  0x20000219, 0x20000219, 0x20000e91, 0x20000219, 0x20000219, 0x20000219,  0x20000219, 0x20000cbd, 0x20000219, 0x20000219, 0x20000219, 0x20000219,  0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x20000219,  0x20000219, 0x20000219, 0x20000219, 0x20000219, 0x200018d0, 0x200018d0, 0x18,  0x200018e8, 0x1c8, 0xbf00e7fe, 0xbf00e7fe, 0xbf00e7fe, 0xbf00e7fe, 0xbf00e7fe,  0xbf00e7fe, 0xbf00e7fe, 0xbf00e7fe, 0xbf00e7fe, 0x4a164b15, 0x4293b570,  0x330cd202, 0xd3fc4293, 0x42ab4d13, 0x2100d21b, 0x42abe001, 0x6858d217,  0x3308681c, 0xd0f82800, 0x1e462204, 0x51094290, 0x680f3c6, 0xb11ed9f1,  0x42902208, 0xd9ec6061, 0x51111d16, 0x42903208, 0xd9e65131, 0xf000e7f8,  0xf000fd63, 0xe7fefedd, 0x20000118, 0x20000124, 0x2000012c, 0xb1aab430,  0x1e536804, 0xf3c3600c, 0x23040480, 0xd90d429a, 0x6844b124, 0x429a2308,  0xd907604c, 0x1d1c581d, 0x5825505d, 0x429a3308, 0xd8f75065, 0x4770bc30,  0xb191b410, 0xf3c31e4b, 0x23040280, 0x42992400, 0xd90a5024, 0x2308b11a,  0x60444299, 0x1d1ad905, 0x3308501c, 0x50144299, 0xbc10d8f9, 0xbf004770,  0xbf00e7fe, 0x4ff0e92d, 0xb0834d2d, 0x3bfff04f, 0x591ff248, 0x16e0f24a,  0x80acf8df, 0xf8cd4f29, 0x2400b004, 0xfde2f000, 0xf00046aa, 0xf2c5fa15,  0xf00019eb, 0xf2c4fa8d, 0x46580602, 0x4283682b, 0xf8dad011, 0xfba93000,  0x21641003, 0xfb010942, 0xb1c03012, 0x3000f898, 0x201f083, 0xf04302d3,  0x60f06000, 0x5a16828, 0xb9130d8b, 0x6280f44f, 0x783a60b2, 0x40912101,  0xbf04428b, 0x6380f44f, 0x34016073, 0xf000e7da, 0xf898f823, 0xb1533000,  0x783a9901, 0xd006428a, 0x98019201, 0xfc20f000, 0x781b4b09, 0x9a01e7d8,  0xd0d53201, 0xd1d32b00, 0x31fff04f, 0x91012010, 0xfc12f000, 0xbf00e7ca,  0x20001960, 0x2000194d, 0x2000194c, 0xbf004770, 0xcfcf641, 0x5340f44f,  0x302f2c4, 0xf2c22200, 0xf8cc0c00, 0x651a2004, 0x20026d19, 0x11c7f362,  0x65192201, 0x605a6058, 0xbf004770, 0x00000000, 0x4ff0e92d, 0x280eb10,  0x4680b087, 0xf0009205, 0x4da780ce, 0x31fff102, 0x6bae6a28, 0x6bef6a6c,  0xebc71b82, 0xfb080904, 0x23ff9902, 0xf0019302, 0xf04f0a01, 0xf1b90b00,  0xf0400f00, 0x990580dd, 0x428c2401, 0x80b0f000, 0xf00f1ba, 0xfbb4d024,  0xfb08f6f8, 0xf1064916, 0xf106000f, 0xf8550709, 0xf855a020, 0xf1067027,  0xebca0208, 0x360e0307, 0x3c03fb09, 0x22f855, 0x6026f855, 0x108ebc9,  0x900ebc6, 0xc909fb01, 0xf0c045cb, 0x990580cd, 0x428c3401, 0x8088f000,  0xf2f8fbb4, 0x4a12fb08, 0x609f102, 0x70ff102, 0x6026f855, 0x7027f855, 0x8f102,  0x320e1bf3, 0x3c03fb0a, 0x20f855, 0x9022f855, 0x108ebca, 0xa00ebc9,  0xca0afb01, 0xd22f45d3, 0xf992f001, 0x100e9cd, 0x7080f509, 0xf98cf001,  0xe9d3a370, 0xf0012300, 0x4602f8cb, 0xe9dd460b, 0xf0010100, 0x2800f985,  0x4630d179, 0xf97cf001, 0x100e9cd, 0x7080f507, 0xf976f001, 0xe9d3a365,  0xf0012300, 0x4602f8b5, 0xe9dd460b, 0xf0010100, 0x9a02f96f, 0xbf182800,  0x92024622, 0x46d3bf18, 0xfbb43401, 0xfb08f2f8, 0xf1024a12, 0xf1020609,  0xf855070f, 0xf8556026, 0xf1027027, 0x1bf10008, 0xfb0a320e, 0xf8551301,  0xf8550020, 0xebca9022, 0xebc90108, 0xfb010c00, 0x45d33a0c, 0xf001d28d,  0xe9cdf943, 0xf5090100, 0xf0017080, 0xa349f93d, 0x2300e9d3, 0xf87cf001,  0x460b4602, 0x100e9dd, 0xf936f001, 0x9905b178, 0x34019402, 0x46d3428c,  0xaf78f47f, 0x2b7f9b02, 0x4841d954, 0x70022200, 0xe8bdb007, 0x46308ff0,  0xf91ef001, 0x100e9cd, 0x7080f507, 0xf918f001, 0xe9d3a336, 0xf0012300,  0x460bf857, 0xe9dd4602, 0xf0010100, 0x9b02f911, 0xbf182800, 0x93024623,  0x46d3bf18, 0x9402e74d, 0xe79d46d3, 0xf900f001, 0x102e9cd, 0x7080f506,  0xf8faf001, 0xe9d3a327, 0xf0012300, 0x4602f839, 0xe9dd460b, 0xf0010102,  0xb310f8f3, 0xb008f8cd, 0xe70a46cb, 0xf8e8f001, 0x100e9cd, 0x7080f506,  0xf8e2f001, 0xe9d3a31b, 0xf0012300, 0x4602f821, 0xe9dd460b, 0xf0010100,  0x2800f8db, 0x9402d034, 0xe71a46cb, 0x48174b16, 0x21019a02, 0x70027019,  0x4620e7a6, 0xf8c8f001, 0x102e9cd, 0x7080f507, 0xf8c2f001, 0xe9d3a30b,  0xf0012300, 0x460bf801, 0xe9dd4602, 0xf0010102, 0x2800f8bb, 0x23ffbf0c,  0x93022300, 0xf04fbf0c, 0x46cb0b00, 0xbf00e6cd, 0x8000f3af, 0x33333333,  0x3ff33333, 0x200018fc, 0x2000194c, 0x2000194d, 0xf0014638, 0x4606f89d,  0x7080f50a, 0xf001460f, 0xa30af897, 0x2300e9d3, 0xffd6f000, 0x4602460b,  0x46304639, 0xf890f001, 0x28009b02, 0x4623bf18, 0xbf189302, 0xe6cc46cb,  0x8000f3af, 0x33333333, 0x3ff33333, 0x4a14b430, 0x5340f44f, 0x302f2c4,  0x68518c1d, 0xf101b2ad, 0xf8420408, 0x20025024, 0x7400f04f, 0x609c2904,  0xd80e6098, 0xf8521ccc, 0x31014024, 0x651c6051, 0x22016d19, 0x11c7f36f,  0x60586519, 0xbc30605a, 0x6d1a4770, 0x12c7f36f, 0xbc30651a, 0xbe56f7ff,  0x200018fc, 0x4161f44f, 0x481db470, 0x100f2ce, 0xf8c12480, 0x24034084,  0xf44f6144, 0x24085240, 0x61842300, 0x24092601, 0xf2c42502, 0x61c40202,  0x60434601, 0x60c66083, 0x46146105, 0x65132006, 0xf36f6d13, 0x651313c7,  0x60566055, 0x7db6813, 0x60a5d4fc, 0xfa1f8c23, 0xf5acfc83, 0x638b7380,  0x38013104, 0x688bd001, 0xf44fe7e9, 0xf2ce4061, 0x22800000, 0x2184f8c0,  0xbc706042, 0xbf004770, 0x200018fc, 0xb4102200, 0x203f2c4, 0x631424a5,  0x4050f44f, 0x1340f24a, 0x631424dd, 0x302f2c4, 0xf2c42108, 0x22020002,  0x64596242, 0xbc106259, 0xbf004770, 0x3f4f641, 0x300f2c2, 0x601a2201,  0xbf004770, 0xbf004770, 0xbf004770, 0xf0f641, 0xcecf641, 0xf2c2, 0xf2c22203,  0xf44f0c00, 0x21014300, 0xf2c46002, 0xf8cc0301, 0x6d181000, 0x3280f440,  0x4770651a, 0xbf004770, 0x1f0f641, 0xcecf641, 0xf2c22001, 0xf2c20100,  0xf44f0c00, 0x60084300, 0x301f2c4, 0xf8cc, 0x200f8d3, 0x280f040, 0x2200f8c3,  0xbf004770, 0xbf282940, 0x7832140, 0xd073b4f0, 0xd06e2900, 0xf8134603,  0xf44f0b01, 0x1e4a4400, 0x401f2c4, 0xf03f013, 0x830f884, 0x1f002, 0x2a00d013,  0xb110d05d, 0x2a00e008, 0xf813d059, 0x3a01cb01, 0xf8840798, 0xd006c830,  0xcb01f813, 0x7983a01, 0xc830f884, 0x2a03d1ef, 0x1f16d929, 0x4635461c,  0x4700f44f, 0xb04f854, 0x701f2c4, 0xf8c72d03, 0xf3c60830, 0xd9130680,  0xf854b136, 0x3d040b04, 0xf8c72d03, 0xd90b0830, 0xf8564626, 0x3d080b04,  0x830f8c7, 0x1d346860, 0xf8c72d03, 0xd8f30830, 0xf0201f10, 0x30040003,  0x203f002, 0xb1f2181b, 0xf44f3a01, 0xf8134500, 0xf2c4cb01, 0x46140501,  0xc830f885, 0x201f002, 0xb12ab18c, 0xb01f813, 0xf8853c01, 0xd00a0830,  0xf812461a, 0xf885cb01, 0x7858c830, 0x3c021c53, 0x830f885, 0x4608d1f4,  0x4770bcf0, 0x460a4603, 0xbf00e7ad, 0x4c37b538, 0x1ec36820, 0xd8152b07,  0xf003e8df, 0x14141440, 0x4142115, 0x4c00f44f, 0xc01f2c4, 0x1810f8dc,  0x40f041, 0x810f8cc, 0x3810f8dc, 0x220f043, 0x2810f8cc, 0xf44fbd38,  0xf2c44e00, 0xf8de0e01, 0x25081810, 0x40f041, 0x810f8ce, 0x4d246025,  0x682a4b24, 0x429188d9, 0x4611bf28, 0xd9222940, 0x21404c21, 0xf7ff6820,  0x6823ff4b, 0x1819682a, 0x4e00f44f, 0x60281a10, 0xf2c46021, 0xf8de0e01,  0xf0411810, 0xf8ce0002, 0xbd380810, 0x4c00f44f, 0xc01f2c4, 0x3810f8dc,  0xf0432101, 0xf8cc0240, 0x60212810, 0x4b10bd38, 0xf7ff6818, 0xf44fff29,  0xf2c44c00, 0xf8dc0c01, 0x20012810, 0x108f042, 0x4e00f44f, 0x1810f8cc,  0xe01f2c4, 0xf8de6020, 0xf0411810, 0xf8ce0002, 0xbd380810, 0x200018ec,  0x200018e8, 0x20001958, 0x20001954, 0xf44fb508, 0xf2c44300, 0xf8d30301,  0x7502810, 0xf8d3d508, 0x210b0810, 0x82f36f, 0x810f8c3, 0x60194b19,  0xd50c06d1, 0x4c00f44f, 0xc01f2c4, 0x1810f8dc, 0xf0414b14, 0x21010080,  0x810f8cc, 0x7d26019, 0x4b10d51c, 0x2a0b681a, 0x681bd003, 0xd0052b01,  0x2001e7fe, 0x681b6018, 0xd1f92b01, 0x4e00f44f, 0xe01f2c4, 0x3830f8de,  0x49064a07, 0xf8de6013, 0x20023830, 0x60536008, 0xf898f000, 0x4008e8bd,  0xbf44f7ff, 0x200018ec, 0x20001958, 0x7804b4f0, 0xebb24603, 0xbf240fc4,  0xd27802, 0xd0640788, 0xd05f2a00, 0x4b01f811, 0xf0111e50, 0xf8830f03,  0xf0004030, 0xd0150401, 0xd0532800, 0xe009b114, 0xd04f2800, 0x4b01f811,  0xf0113801, 0xf8830f03, 0xd0074030, 0x4b01f811, 0xf0113801, 0xf8830f03,  0xd1ed4030, 0xd9212803, 0x460c1f06, 0xf8544635, 0x2d037b04, 0xf3c6631f,  0xd9100680, 0xf854b12e, 0x3d046b04, 0x631e2d03, 0x4626d909, 0x7b04f856,  0x631f3d08, 0x1d346867, 0x631f2d03, 0x1f04d8f5, 0x403f024, 0xf0003404,  0x19090003, 0x3801b1d0, 0x5b01f811, 0xf8834604, 0xf0005030, 0xb18c0001,  0xf811b128, 0x3c01cb01, 0xc030f883, 0x4608d00a, 0x5b01f810, 0x5030f883,  0x1c41784d, 0xf8833c02, 0xd1f45030, 0xbcf04610, 0x46104770, 0xbf00e7ba,  0x4b0cb538, 0xb1a2681a, 0x2a01681a, 0x4d0ad1fc, 0xf6484b08, 0x18290480,  0x401f2c4, 0x601d2502, 0xf7ff4620, 0x6921ff7b, 0x8af441, 0x325f040,  0xbd386123, 0x200018f4, 0x200018d0, 0xf2404a44, 0x88136181, 0xd074428b,  0xf5b3d90a, 0xd01e6f10, 0x3201f640, 0xd01a4293, 0x220a493e, 0x4770600a,  0x6fa0f5b3, 0xf5b3d058, 0xd1f56fd0, 0xf5b38853, 0xd0677f80, 0x7f00f5b3,  0x4a37d1ee, 0x60114937, 0x4b372222, 0x21074833, 0x6001601a, 0xf6484770,  0xf2c40080, 0x69010001, 0x324f242, 0x345f2c0, 0x203ea41, 0x69036102,  0x72dbf64b, 0x18af423, 0xc24f021, 0x38af44c, 0x120f043, 0x69036101,  0x72baf6cf, 0xc02ea03, 0x18af44c, 0x324f041, 0x69026103, 0xc8af422, 0x134f02c,  0x38af441, 0x224f043, 0x69016102, 0x4c00f44f, 0x38af441, 0x264f043,  0x61022108, 0xc01f2c4, 0xf8dc7001, 0x4a183050, 0x3000f443, 0xf8cc4b12,  0x21010050, 0x60112003, 0x47706018, 0xf44f8852, 0x4b0d4c00, 0x17ff002,  0xc01f2c4, 0xf8cc2003, 0x60181000, 0x88504770, 0x5f08f5b0, 0x4a0bd18e,  0x601a4b06, 0xe79e2217, 0x4b044809, 0x60182212, 0xbf00e799, 0x20001958,  0x200018ec, 0x20001954, 0x20001864, 0x200018e8, 0x200018f4, 0x2000189c,  0x20001888, 0x360f24d, 0x302f2c4, 0x7d0691a, 0x6918d51f, 0xd41c0781,  0xf013691b, 0xd1180204, 0xc10f24e, 0xc00f2ce, 0x120f44f, 0x1004f8cc,  0x2008f8cc, 0x46612205, 0x2000f8cc, 0xf24e6808, 0x3c20310, 0x300f2ce,  0x2200d5f8, 0x605a601a, 0xf7ff609a, 0xbf00bd1b, 0xf44fb508, 0xf2c45040,  0x68030002, 0xd40b019a, 0x5240f44f, 0x202f2c4, 0x14b6811, 0xbd08d400,  0x4008e8bd, 0xbb00f7ff, 0xfc98f7ff, 0xbf00e7f0, 0x4c50f44f, 0x5340f44f,  0xf2c4b470, 0xf44f0302, 0x26041100, 0xc02f2c4, 0x1024f8cc, 0x2630605e,  0xf44f609e, 0x609e4670, 0x605e2600, 0x250124c0, 0x631d2607, 0x4261f44f,  0x615d619e, 0x605c609c, 0x64e0f44f, 0xf2ce609c, 0x20800200, 0x6480f44f,  0xf8c2605c, 0x60500184, 0xbc706059, 0xbf004770, 0xf000b508, 0xf641f8c9,  0xf44f03e4, 0xf2c25234, 0xf2c00300, 0x601a1231, 0xbf00bd08, 0x4350f44f,  0xf2c42202, 0xf2c50302, 0x625a0220, 0xbf004770, 0x1360f641, 0x300f2c2,  0x1c426818, 0x4770601a, 0xbf00e7fe, 0xbf00e7fe, 0xbf00e7fe, 0xbf00e7fe,  0xbf00e7fe, 0xf641b430, 0xf2c205e4, 0x68290500, 0xfb002032, 0xf644fc01,  0xf2c152d3, 0xf64c0262, 0xfba2236b, 0xf6c65401, 0xfba3335f, 0x9a1250c,  0x310f24e, 0x300f2ce, 0xde81e4c, 0x4c6df44f, 0x605c2210, 0xc00f2ce, 0x204f2ce,  0x24f03801, 0x21072500, 0x4023f88c, 0x6019609d, 0xbc306010, 0xbf004770,  0xbf004770, 0xf7ffb508, 0xf000ffaf, 0xf641f815, 0xf44f03e4, 0xf2c25234,  0xf2c00300, 0x601a1231, 0xffbef7ff, 0xff92f7ff, 0xffbaf7ff, 0xff5ef7ff,  0x4008e8bd, 0xbfe4f7ff, 0x2a0f24a, 0xf2c4b4f0, 0x241e0202, 0x1340f24a,  0x4120f44f, 0x10e0f24a, 0xf2c46294, 0x60540302, 0x7cc0f44f, 0x27086314,  0x102f2c4, 0x4500f04f, 0x2f2c4, 0x6640f44f, 0x72c4f44f, 0xc028f8c3,  0xc004f8c3, 0x625f645f, 0x634d631a, 0x62466446, 0xbcf0644d, 0xbf004770,  0xf44fb538, 0xf2c44300, 0x6b1c0301, 0x631c6a1d, 0x621d07ea, 0x7abd41a,  0x720d415, 0x7a1d410, 0x762d40b, 0x7e3d406, 0xbd38d400, 0x4038e8bd,  0xbc50f7ff, 0xfc38f7ff, 0xf7ffe7f5, 0xe7f0fc33, 0xfc2ef7ff, 0xf7ffe7eb,  0xe7e6fc23, 0xfd52f7ff, 0xbf00e7e1, 0x4300f44f, 0x301f2c4, 0xf8c32280,  0xf8d32314, 0x22000300, 0x140f040, 0x1300f8c3, 0x621a631a, 0xf44f6c18,  0xf0404c61, 0x64190101, 0xf2ce6d18, 0xf0400c00, 0x65190104, 0x2200f8c3,  0x200f8d3, 0x120f040, 0x1200f8c3, 0x200f8d3, 0x140f040, 0x1200f8c3,  0xf0406e18, 0x66190180, 0xf3626e18, 0x66181045, 0x20046e19, 0x1186f362,  0xf8cc6619, 0x69190004, 0x1104f362, 0x47706119, 0xb5102000, 0x46024601,  0xf804f000, 0x4010e8bd, 0xb954f7ff, 0x2100b510, 0x72a0f44f, 0xf000481e,  0x20c0f86b, 0xf9a2f000, 0x21004c1c, 0x602022c0, 0xf862f000, 0x68224b18,  0x71a0f503, 0x3328625a, 0x428b3218, 0x2000d1fa, 0x4a134915, 0xf878f000,  0xf44f2100, 0xf44f5380, 0x480f6280, 0xf828f000, 0x49102001, 0xf0004a10,  0x2100f86b, 0x5380f44f, 0x6280f44f, 0xf000480c, 0x2002f81b, 0x4a0b4909,  0xf85ef000, 0x21004809, 0x6280f44f, 0x5380f44f, 0x4010e8bd, 0xb80cf000,  0x20001968, 0x20001964, 0x200018b4, 0x200018b6, 0x20001990, 0x200019b8,  0x68c4b570, 0xf03f014, 0xf5b2d017, 0xd0097f00, 0x6f80f5b2, 0xf5b2d003,  0xd10e7f80, 0x6a41e002, 0xe0032301, 0x1e5e4d07, 0xd80842ae, 0x61014322,  0x61c36001, 0x200060c2, 0x2001bd70, 0x2001bd70, 0xbf00bd70, 0xfffffe,  0xbb8cf000, 0xb51068c3, 0x320f023, 0x6a4360c3, 0x685b6982, 0x429a4604,  0xf000d00f, 0x68e3f84c, 0xf4236a62, 0xf0235340, 0xf0430310, 0x60e30310,  0x61a36853, 0x60936923, 0x68e36023, 0x4380f423, 0x340f023, 0xbd1060e3,  0x460eb570, 0x46104605, 0xf0004614, 0x7833f91f, 0xd0042b72, 0xd0092b77,  0xd1252b61, 0x2300e002, 0xe0052201, 0xf2482308, 0xe0010202, 0x22022304,  0x1f01f816, 0xd002292b, 0xd10a2962, 0xf042e004, 0xf0430203, 0xe7f30302,  0x204f042, 0x301f043, 0xf013e7ee, 0x60e20f08, 0xd0066165, 0x21004620,  0xf0002202, 0xe000f947, 0x46202400, 0xb538bd70, 0x46046801, 0x69056a43,  0x689b68c0, 0x2200f420, 0xf00060e2, 0x2a020282, 0xf410d117, 0xd0193080,  0xbf384299, 0x42a94619, 0x4628d005, 0x46221b49, 0xf812f000, 0x6a63b960,  0x609d2000, 0x602568e3, 0x3380f423, 0x60e360a0, 0xf04fbd38, 0xbd3830ff,  0x30fff04f, 0xbd38, 0x41f0e92d, 0x460668d7, 0x1f80f417, 0x4614460d,  0x8014f8d2, 0x4640d005, 0xfb16f000, 0x710f047, 0x4b1861a0, 0x303ea07,  0x4640b193, 0xf00069a1, 0x2800fb1d, 0x68e3da07, 0x30fff04f, 0x380f043,  0xe8bd60e3, 0xf42781f0, 0xf0273700, 0x60e70710, 0x4640462a, 0xf0004631,  0x69a3fb15, 0xbf1442a8, 0x30fff04f, 0x18ed2000, 0x4300f020, 0x61a51aed,  0x68e3b128, 0x30fff04f, 0x380f043, 0xe8bd60e3, 0xbf0081f0, 0x20010,  0xe92d4b32, 0x1cc541f0, 0x8ad681c, 0x28004698, 0x2700d05a, 0x6821e03f,  0x5f80f1b1, 0x68a6d139, 0xf1b36833, 0x68635f80, 0x6872d106, 0x3303189b,  0x68b36063, 0xe02e60a3, 0xd10642ab, 0xf04f4620, 0xf8405300, 0xe8bd3b0c,  0x1cea81f0, 0xd9104293, 0xf04f4620, 0xf8405200, 0x1b5b2b0c, 0x285eb00,  0x60653b03, 0xf84060a2, 0x60531025, 0xe8bd6096, 0xb97681f0, 0x1ac0009b,  0xfac6f000, 0x3ffff1b0, 0xf04fd01e, 0x60235300, 0xf1046065, 0xe8bd000c,  0x462781f0, 0x2c0068a4, 0x300cd1bd, 0xfab4f000, 0x3ffff1b0, 0xf04fd00f,  0x60035300, 0x60846045, 0xf8c8b917, 0xe0000000, 0x300c60b8, 0x81f0e8bd,  0xe8bd4630, 0x462081f0, 0x81f0e8bd, 0x20001aa8, 0x5380f04f, 0x3c0cf840,  0x4770, 0xf7ffb510, 0x4604ff8f, 0x4904b928, 0xf0002217, 0xf000fa87,  0x4620fa5b, 0xbf00bd10, 0x200018b8, 0x41f0e92d, 0xb08668c6, 0xf03f016,  0xf8d04604, 0x69078014, 0xd0276a45, 0xf08f016, 0xf000d117, 0x4640f829,  0xfa48f000, 0x6f00f416, 0x4638d002, 0xffd0f7ff, 0x5b60db6, 0x4fa5f116,  0xa801d107, 0x22146a21, 0xfa56f000, 0xf000a801, 0x2100f8dd, 0x6a602218,  0xfe8af7ff, 0x21004620, 0xf7ff2228, 0x6265fe85, 0xe0012000, 0x30fff04f,  0xe8bdb006, 0x81f0, 0x4604b570, 0xe8bdb118, 0xf0004070, 0x4605b8f4,  0x20284b07, 0x3004fb00, 0xf8edf000, 0x28003401, 0xf04fbf18, 0x2c0835ff,  0x4628d1f2, 0xbf00bd70, 0x20001968, 0x41f0e92d, 0x68c64b41, 0xea064604,  0x460d0303, 0xf8d04617, 0x2b008014, 0x4640d071, 0xfa04f000, 0xd16c2800,  0xd0042f01, 0xd0072f02, 0xd0272f00, 0x4620e065, 0xf86cf000, 0xe021182d,  0xf0004640, 0x2800f9ed, 0x68e3da06, 0xf0432001, 0x60e30380, 0x81f0e8bd,  0x69a16a62, 0x68936827, 0xbf2c429f, 0x18cb19cb, 0x1a5b6921, 0xf01168e1,  0xd0030f20, 0x42936852, 0x4613bfb8, 0xbfac4283, 0x182d18ed, 0xdb3f2d00,  0x5f00f416, 0x6a63d005, 0x68996822, 0xbf384291, 0x69a3609a, 0xdb0e429d,  0x68216a60, 0x42916882, 0x4611bf38, 0x18cf6922, 0x42bd1abf, 0x68c0dc03,  0x42bd18c7, 0x2300db07, 0x606360a3, 0xf0466a63, 0x605d0620, 0xf016e011,  0xebc30f02, 0xbf1c0505, 0x5ebc0, 0xf01660a0, 0xd0020f01, 0x19491a51,  0x19556061, 0xf0266025, 0xf4260620, 0xf4262602, 0x60e65682, 0xe8bd2000,  0x200281f0, 0x81f0e8bd, 0xe8bd2002, 0xbf0081f0, 0x100003, 0xf01368c3,  0xd1050f03, 0x22214b10, 0xf04f601a, 0x477030ff, 0x2f00f413, 0x320f003,  0xb11bd00b, 0x68586a43, 0x47703801, 0x68016903, 0x43db6982, 0x18181888,  0xb1134770, 0x68586a43, 0x69834770, 0x18d26802, 0x1ad06903, 0xbf004770,  0x200018f8, 0x4604b510, 0xf806f000, 0x46204601, 0x4010e8bd, 0xb960f000,  0x1c41b510, 0xf810e004, 0xb90b3b01, 0xbd101a40, 0xf03f010, 0x4602d1f7,  0x3b04f850, 0x3401f1a3, 0x403ea24, 0x3f80f014, 0xf013d0f5, 0xd00b0fff,  0x4f7ff413, 0xf413d006, 0xd0010f7f, 0xe0041d13, 0xe0021cd3, 0xe0001c93,  0x1a581c53, 0x68c3bd10, 0xf013b570, 0x46050403, 0xf013d019, 0xd0040f20,  0x685e6a43, 0xfd76f7ff, 0x6983e004, 0x18f66806, 0x1af66903, 0x462868eb,  0x5340f423, 0xf7ff60eb, 0x4631fdc2, 0x22004604, 0xf7ff4628, 0x4620feff,  0xbd70, 0x4ff0e92d, 0x5760d0e, 0x460f0d76, 0x461d4614, 0x2e00469c, 0xf240d05c,  0x428e71ff, 0xd1bd058, 0xd5b055b, 0xd0532b00, 0xd051428b, 0x107ea85,  0x477ff027, 0x770f427, 0x2ac2ea4f, 0x1780f447, 0x890afba7, 0xab00fbaa,  0xd5318f6, 0x2cc5ea43, 0xeb1b2500, 0xf1450408, 0xf04c0500, 0xfbe04c00,  0x2300450c, 0x209eb15, 0x300f143, 0x230cfbe7, 0x1f80f5b3, 0x6680f5a6,  0x4100f001, 0x49aea44, 0x1892d206, 0x303eb43, 0x43020fe0, 0xe0000064,  0xfe03601, 0xf1431812, 0x46180300, 0x4f00f1b4, 0x73fdf240, 0xf022bf08,  0x429e0201, 0xea41d806, 0x5360300, 0x461018f1, 0x8ff0e8bd, 0xbfa42e00,  0x41fef041, 0x170f441, 0x46102200, 0x8ff0e8bd, 0x207ea8c, 0x1300f46f,  0x429f007f, 0x4200f002, 0xebb3d806, 0xd3060f4c, 0x20004611, 0x8ff0e8bd,  0x1f00f517, 0xea4fd10b, 0xf51c0c4c, 0xd8061f00, 0x57f0d7f, 0xea4fb11f,  0x55b535c, 0x2000b91b, 0xe8bd4904, 0xf0428ff0, 0xf44141fe, 0x20000170,  0x8ff0e8bd, 0x7ff80000, 0x4603b910, 0xe0204602, 0xd1010c03, 0xe0010400,  0x7180f101, 0xd1010e03, 0xe0010200, 0x100f501, 0xd1010f03, 0xe0010100,  0x180f501, 0xd1010f83, 0xe0010080, 0x1100f501, 0xdb012800, 0xe0010040,  0x1180f501, 0x23e0eb01, 0x46100542, 0x47704619, 0x4180f04f, 0xbfd4f7ff,  0x460eb570, 0x4619461d, 0x306ea55, 0x446ea4f, 0xf514d407, 0xd8171f00,  0xd81942ae, 0x4290d114, 0xf514e00e, 0xd80f1f00, 0xf513006b, 0xd80b1f00,  0xd1014304, 0xd0094313, 0xd80942b1, 0x4282d10a, 0x2000bf94, 0xbd702001,  0xbd702000, 0xbd704618, 0xbd702001, 0xbd702000, 0x3a044603, 0xb2c9d308,  0x2101ea41, 0x4101ea41, 0xf8433a04, 0xd2fb1b04, 0xd0023204, 0x54993a01,  0x4770d1fc, 0x49012018, 0x4770beab, 0x20026, 0x4669b403, 0xbeab2002,  0x4770b002, 0x4669b403, 0xbeab200c, 0x4770b002, 0x4669b403, 0xbeab2009,  0x4770b002, 0x4669b403, 0xbeab200e, 0x4770b002, 0x4669b403, 0xbeab200a,  0x4770b002, 0x4669b40f, 0xbeab200d, 0x4770b004, 0x4669b40f, 0xbeab2005,  0x4770b004, 0x4b0cb538, 0xb90a681a, 0x601a4a0b, 0x681c1cc5, 0x503f025,  0x46281965, 0xf812f000, 0x4b05b910, 0xe004601d, 0x220c4b05, 0xf04f601a,  0x462034ff, 0xbf00bd38, 0x20001aac, 0x20001ab0, 0x200018f8, 0x466b4a08,  0xd9014293, 0xd2064298, 0xb1334b06, 0xbf344298, 0x20012000, 0x20014770,  0x46184770, 0xbf004770, 0x20001ab0, 0x00000000, 0x220209, 0xc0000101, 0x40932,  0x30100, 0x21090000, 0x1000100, 0x7001722, 0x40038105, 0x100, 0x2000112,  0x40000000, 0xfffeffff, 0x100, 0x100, 0x7090105, 0x70501a1, 0x65290019,  0x65250015, 0x1950875, 0xc00081, 0x770072, 0x202a2a2a, 0x7973435f, 0x6c615f73,  0x20636f6c, 0x6c696166, 0xa6465, 0x5b5a5962, 0x5f5e5d5c, 0x636160, 0x00000000,  0x00000000, 0x1312d00, };

 

//// Copyright (c) 2013 SILICON LABORATORIES, INC.//// FILE NAME    : dp_swd.c// TARGET MCU   : C8051F380// DESCRIPTION  : ARM CoreSight SW-DP Interface//// This file implements an interface to the ARM CoreSight Serial Wire Debug// (SWD) - Debug Port (DP).//#include 
#include "32bit_prog_defs.h"//-----------------------------------------------------------------------------// Project Variables//-----------------------------------------------------------------------------// Holds the last acknowledge error from the start of a move command.// Also used by the Serial Wire module.U8 idata ack_error;#if 1// Note how the bit addresses are arranged to provide an endian swap.// io_word is stored BE (matches the Keil C compliler), while the bit addresses// are LE (matches the wire interface).SEGMENT_VARIABLE( io_word, UU32, SEG_BDATA );// Used to provide bit addressable data for 8-bit and smaller shift routines.// Also used by the Serial Wire module.SEGMENT_VARIABLE( io_byte, U8, SEG_BDATA );SBIT (iow_0, io_word.U32, 24);SBIT (iow_1, io_word.U32, 25);SBIT (iow_2, io_word.U32, 26);SBIT (iow_3, io_word.U32, 27);SBIT (iow_4, io_word.U32, 28);SBIT (iow_5, io_word.U32, 29);SBIT (iow_6, io_word.U32, 30);SBIT (iow_7, io_word.U32, 31);SBIT (iow_8, io_word.U32, 16);SBIT (iow_9, io_word.U32, 17);SBIT (iow_10, io_word.U32, 18);SBIT (iow_11, io_word.U32, 19);SBIT (iow_12, io_word.U32, 20);SBIT (iow_13, io_word.U32, 21);SBIT (iow_14, io_word.U32, 22);SBIT (iow_15, io_word.U32, 23);SBIT (iow_16, io_word.U32, 8);SBIT (iow_17, io_word.U32, 9);SBIT (iow_18, io_word.U32, 10);SBIT (iow_19, io_word.U32, 11);SBIT (iow_20, io_word.U32, 12);SBIT (iow_21, io_word.U32, 13);SBIT (iow_22, io_word.U32, 14);SBIT (iow_23, io_word.U32, 15);SBIT (iow_24, io_word.U32, 0);SBIT (iow_25, io_word.U32, 1);SBIT (iow_26, io_word.U32, 2);SBIT (iow_27, io_word.U32, 3);SBIT (iow_28, io_word.U32, 4);SBIT (iow_29, io_word.U32, 5);SBIT (iow_30, io_word.U32, 6);SBIT (iow_31, io_word.U32, 7);SBIT (iob_0, io_byte, 0);SBIT (iob_1, io_byte, 1);SBIT (iob_2, io_byte, 2);SBIT (iob_3, io_byte, 3);SBIT (iob_4, io_byte, 4);SBIT (iob_5, io_byte, 5);SBIT (iob_6, io_byte, 6);SBIT (iob_7, io_byte, 7);#elseUU32 io_word;volatile U8 bdata io_byte;#endif//-----------------------------------------------------------------------------// Variables Declarations//-----------------------------------------------------------------------------// Controls SW connection sequence. 0=SW-DP, 1=SWJ-DP (use switch sequence)U8 idata swj_dp_type;// Even parity lookup table, holds even parity result for a 4-bit value.const U8 code even_parity[] ={ 0x00, 0x10, 0x10, 0x00, 0x10, 0x00, 0x00, 0x10, 0x10, 0x00, 0x00, 0x10, 0x00, 0x10, 0x10, 0x00};//-----------------------------------------------------------------------------// SWD Host Command Handlers//-----------------------------------------------------------------------------//-----------------------------------------------------------------------------// StrobeSWCLK//-----------------------------------------------------------------------------//// Pulls SWCLK high then low.//#define _StrobeSWCLK { SWCLK_Out = 1; SWCLK_Out = 0; };//-----------------------------------------------------------------------------// SWD_Initialize//-----------------------------------------------------------------------------//// Initializes SWD configuration data at startup.//void SWD_Initialize( void ){ swj_dp_type = FALSE; // Default DP type is DP-SW}//-----------------------------------------------------------------------------// (0x20) SWD_Configure//-----------------------------------------------------------------------------//// Sets the debug port (DP) type to either Serial Wire only or Serial Wire JTAG.// The firmware needs to know this because the connection sequence is different// depending on the DP type.//// Parameters:// 1. DP_Type - Debug Port type. 0=SW, 1=SWJ//// Returns:// 1. HOST_COMMAND_OK//STATUS SWD_Configure( U8 dp_type ){ swj_dp_type = dp_type; return HOST_COMMAND_OK;}//-----------------------------------------------------------------------------// (0x21) SWD_Connect//-----------------------------------------------------------------------------//// Sets the target device for Serial Wire communication and returns the// 32-bit ID code. Must be called before performing any SWD commands.//// Returns:// 1-4. IDCODE - Value read from the IDCODE register (32-bit).// 5. Response code.//STATUS SWD_Connect( void ){ U8 rtn; // Initialize IO pins for SWD interface _SetSWPinsIdle; // Select the Serial Wire Debug Port // Skip this switch sequence if the device does not have the swj_dp port // Serial Wire + JTAG SW_ShiftReset( ); SW_ShiftByteOut( 0x9E ); SW_ShiftByteOut( 0xE7 ); // Reset the line and return the 32-bit ID code rtn = SWD_LineReset( ); //SendLongToHost(io_word.U32); return rtn;}//-----------------------------------------------------------------------------// (0x30) SWD_Disconnect//-----------------------------------------------------------------------------//// Switches the debug interface to JTAG communication and disconnects pins.//// Returns:// 1. HOST_COMMAND_OK//STATUS SWD_Disconnect( void ){ // Initialize IO pins for SWD interface _SetSWPinsIdle; // Select the JTAG Debug Port // Skip this switch sequence if the device does not have the swj_dp port // Serial Wire + JTAG SW_ShiftReset( ); SW_ShiftByteOut( 0x3C ); SW_ShiftByteOut( 0xE7 ); // Release debug interface pins except nSRST _ResetDebugPins; return HOST_COMMAND_OK;}//-----------------------------------------------------------------------------// (0x31) SWD_LineReset//-----------------------------------------------------------------------------//// Performs a line reset on the Serial Wire interface.//// Returns:// 1. Response code.//STATUS SWD_LineReset( void ){ U8 ack; // Complete SWD reset sequence (50 cycles high followed by 2 or more idle cycles) SW_ShiftReset( ); SW_ShiftByteOut( 0 ); // Now read the DPIDR register to move the SWD out of reset ack = SW_ShiftPacket( SW_IDCODE_RD, 1 ); SW_ShiftByteOut( 0 ); return SW_Response( ack );}//-----------------------------------------------------------------------------// (0x32) SWD_ClearErrors//-----------------------------------------------------------------------------//// Clears all the error/sticky bits in the DP Control/Status register.//// Returns:// 1-4. DP_CSR - DP_CTRLSTAT register value before the clear (32-bit, LE).// 5-8. DP_CSR - DP_CTRLSTAT register value after the clear (32-bit, LE).// 9. Response code.//STATUS SWD_ClearErrors( void ){ U8 ack; // First read the DP-CSR register and send the value to the host. SW_ShiftPacket( SW_CTRLSTAT_RD, 1 ); //SendLongToHost(io_word.U32); // Clear all error/sticky bits by writing to the abort register. io_word.U32 = 0x1E; SW_ShiftPacket( SW_ABORT_WR, 1 ); // Read the DP-CSR register again and send the results to the host. ack = SW_ShiftPacket( SW_CTRLSTAT_RD, 1 ); SW_ShiftByteOut( 0 ); //SendLongToHost(io_word.U32); return SW_Response( ack );}//-----------------------------------------------------------------------------// (0x34) SWD_DAP_Move//-----------------------------------------------------------------------------//// Reads or writes one Debug/Access Port address one or more times.//// Parameters:// 1. Count - Number of words to transfer minus one (i.e. 0=move 1 word).// 2. DAP_Addr - The DAP register address to transfer one or more times.// 3-n. Words[] - Array of 32-bit LE words (write transfers only).//// Returns:// 1-n. Words[] - Array of 32-bit LE words (read transfers only).// n+1. Response code.//// Uses:// ack_error - Resets error accumulator.//STATUS SWD_DAP_Move( U8 cnt, U8 dap, U32 * transfer_data ){ // Reset global error accumulator ack_error = SW_ACK_OK; // Determine if this is a read or write transfer if ( dap & DAP_CMD_RnW ) { // Perform the requested number of reads SW_DAP_Read( cnt, dap, transfer_data ); } else { SW_DAP_Write( cnt, dap, transfer_data, TRUE ); } // Finish with idle cycles SW_ShiftByteOut( 0 ); // Return the accumulated error result return SW_Response( ack_error );}//-----------------------------------------------------------------------------// SWD Helper Functions//-----------------------------------------------------------------------------//-----------------------------------------------------------------------------// SW_Response//-----------------------------------------------------------------------------//// Converts SWD acknowledge value into a host response code.//// Parameters:// SW_Ack - 3-bit SWD acknowledge code.//// Returns:// 8-bit host response code.//STATUS SW_Response( U8 SW_Ack ){ switch ( SW_Ack ) { case SW_ACK_OK: return HOST_COMMAND_OK; case SW_ACK_WAIT: return HOST_AP_TIMEOUT; case SW_ACK_FAULT: return HOST_ACK_FAULT; default: return HOST_WIRE_ERROR; }}//-----------------------------------------------------------------------------// SW_DAP_Read//-----------------------------------------------------------------------------//// Does one or more reads of one Debug/Access Port register and returns each// 32-bit word to the host.//// Parameters:// cnt - Number of words to read minus one (i.e. 0=read 1 word).// DAP_Addr - The DAP register address to read one or more times.//void SW_DAP_Read( U8 cnt, U8 DAP_Addr, U32 * read_data ){ U8 req; // Format the packet request header req = SW_Request( DAP_Addr ); // Shift the first packet and if DP access, send the results SW_ShiftPacket( req, 0 ); if ( !( req & SW_REQ_APnDP ) ) { *read_data = io_word.U32; read_data++; } // Perform the requested number of reads for ( ; cnt != 0; cnt-- ) { SW_ShiftPacket( req, 0 ); *read_data = io_word.U32; read_data++; } // For AP access, get and send results of the last read if ( req & SW_REQ_APnDP ) { SW_ShiftPacket( SW_RDBUFF_RD, 0 ); *read_data = io_word.U32; read_data++; }}//-----------------------------------------------------------------------------// SW_DAP_Write//-----------------------------------------------------------------------------//// Does one or more writes to one Debug/Access Port register getting each// 32-bit word from the host.//// Parameters:// cnt - Number of words to write minus one (ie 0=write 1 word).// DAP_Addr - The DAP register address to write one or more times.// final - True if this is the final transfer of a move sequence.//void SW_DAP_Write( U8 cnt, U8 DAP_Addr, U32 * write_data, BOOL final ){ U8 req; // Format the packet request header req = SW_Request( DAP_Addr ); // Perform the requested number of writes do { io_word.U32 = *write_data; write_data++;#if 0 // Clear the upper half word for 16-bit packed writes io_word.U16[MSB] = 0; // For packed transfers, write 16-bits at a time if (DAP_Addr & DAP_CMD_PACKED) { SW_ShiftPacket(req, 0); io_word.U32 = *write_data; write_data++; // Clear the upper half word for 16-bit packed writes io_word.U16[MSB] = 0; } else { io_word.U16[MSB] = (U16) *write_data; write_data++; }#endif SW_ShiftPacket( req, 0 ); }while ( cnt-- != 0 ); // For AP access, check results of last write (use default retry count // because previous write may need time to complete) if ( final && ( req & SW_REQ_APnDP ) ) { SW_ShiftPacket( SW_RDBUFF_RD, 0 ); }}//-----------------------------------------------------------------------------// SW_Request//-----------------------------------------------------------------------------//// Converts DAP address into SWD packet request value.//// Parameters:// DAP_Addr - 4-bit DAP address (A3:A2:RnW:APnDP).//// Returns:// Complete 8-bit packet request value. Includes parity, start, etc.//U8 SW_Request( U8 DAP_Addr ){ U8 req; // Convert the DAP address into a SWD packet request value req = DAP_Addr & DAP_CMD_MASK; // mask off the bank select bits req = req | even_parity[ req ]; // compute and add parity bit req = req << 1; // move address/parity bits req = req | SW_REQ_PARK_START; // add start and park bits return req;}//-----------------------------------------------------------------------------// SW_CalcDataParity//-----------------------------------------------------------------------------//// Calculates even parity over the 32-bit value in io_word.U32. Contents of// io_word are not changed.//// Returns:// 1-bit even parity.//// Uses:// io_word - Holds 32-bit value to compute parity on.//bit SW_CalcDataParity( void ){ U8 parity; // Calculate column parity, reducing down to 4 columns parity = io_word.U8[ b0 ]; parity ^= io_word.U8[ b1 ]; parity ^= io_word.U8[ b2 ]; parity ^= io_word.U8[ b3 ]; parity ^= parity >> 4; // Use lookup table to get parity on 4 remaining bits. The cast (bit) // converts any non-zero value to 1. return (bit) even_parity[ parity & 0xF ];}//-----------------------------------------------------------------------------// SW_ShiftReset//-----------------------------------------------------------------------------//// Puts the SWD into the reset state by clocking 64 times with SWDIO high.// Leaves SWDIO an output and high.//void SW_ShiftReset( void ){ U8 i; // Drive SWDIO high SWDIO_Out = 1; _SetSWDIOasOutput; // Complete 64 SWCLK cycles for ( i = 64; i != 0; i-- ) { _StrobeSWCLK }}//-----------------------------------------------------------------------------// SW_ShiftPacket//-----------------------------------------------------------------------------//// Completes one serial wire packet transfer (read or write). Expects SWDIO to// be an output on entry.//// Parameters:// request - Complete 8-bit packet request value. Includes parity, start, etc.// retry - Number of times to try the request while the target ack is WAIT.// 0 = use the system default retry count// n = try the request upto n times//// Returns:// 3-bit SWD acknowledge code.// Leaves SWDIO an output and low.//// Uses:// ack_error - Updated if there was a transfer error.// io_byte - Used for all transfers.// io_word - On entry, holds the 32-bit word data to transfer on writes.// On exit, holds the 32-bit word data transfered on reads.//U8 SW_ShiftPacket( U8 request, U8 retry ){ U8 ack, limit, i; // If retry parameter is zero, use the default value instead if ( retry == 0 ) { retry = DAP_RETRY_COUNT; } limit = retry; // While waiting, do request phase (8-bit request, turnaround, 3-bit ack) do { // Turnaround or idle cycle, makes or keeps SWDIO an output SWDIO_Out = 0; _SetSWDIOasOutput; _StrobeSWCLK // Shift out the 8-bit packet request SW_ShiftByteOut( request ); // Turnaround cycle makes SWDIO an input _SetSWDIOasInput; _StrobeSWCLK // Shift in the 3-bit acknowledge response io_byte = 0; iob_0 = SWDIO_In; _StrobeSWCLK iob_1 = SWDIO_In; _StrobeSWCLK iob_2 = SWDIO_In; _StrobeSWCLK ack = io_byte; // Check if we need to retry the request if ( ( ack == SW_ACK_WAIT ) && --retry ) { // Delay an increasing amount with each retry for ( i = retry; i < limit; i++ ) ; } else { break; // Request phase complete (or timeout) } }while ( TRUE ); // If the request was accepted, do the data transfer phase (turnaround if // writing, 32-bit data, and parity) if ( ack == SW_ACK_OK ) { if ( request & SW_REQ_RnW ) { // Swap endian order while shifting in 32-bits of data io_word.U8[ b0 ] = SW_ShiftByteIn( ); io_word.U8[ b1 ] = SW_ShiftByteIn( ); io_word.U8[ b2 ] = SW_ShiftByteIn( ); io_word.U8[ b3 ] = SW_ShiftByteIn( ); // Shift in the parity bit iob_0 = SWDIO_In; _StrobeSWCLK // Check for parity error if ( iob_0 ^ SW_CalcDataParity( ) ) { ack = SW_ACK_PARITY_ERR; } } else { // Turnaround cycle makes SWDIO an output _SetSWDIOasOutput; _StrobeSWCLK // Swap endian order while shifting out 32-bits of data SW_ShiftByteOut( io_word.U8[ b0 ] ); SW_ShiftByteOut( io_word.U8[ b1 ] ); SW_ShiftByteOut( io_word.U8[ b2 ] ); SW_ShiftByteOut( io_word.U8[ b3 ] ); // Shift out the parity bit SWDIO_Out = SW_CalcDataParity( ); _StrobeSWCLK } } // TODO: Add error (FAULT, line, parity) handling here? RESEND on parity error? // Turnaround or idle cycle, always leave SWDIO an output SWDIO_Out = 0; _SetSWDIOasOutput; _StrobeSWCLK // Update the global error accumulator if there was an error if ( ack != SW_ACK_OK ) { ack_error = ack; } return ack;}//-----------------------------------------------------------------------------// SW_ShiftByteOut//-----------------------------------------------------------------------------//// Shifts an 8-bit byte out the SWDIO pin.//// Parameters:// byte - The 8-bit byte to shift out on SWDIO.//// Uses:// io_byte - Holds byte as it is shifted out.//#pragma OT(8, SPEED)void SW_ShiftByteOut( U8 byte ){ // Make sure SWDIO is an output _SetSWDIOasOutput; // Copy data to bit addressable location io_byte = byte; // Shift 8-bits out on SWDIO SWDIO_Out = iob_0; _StrobeSWCLK SWDIO_Out = iob_1; _StrobeSWCLK SWDIO_Out = iob_2; _StrobeSWCLK SWDIO_Out = iob_3; _StrobeSWCLK SWDIO_Out = iob_4; _StrobeSWCLK SWDIO_Out = iob_5; _StrobeSWCLK SWDIO_Out = iob_6; _StrobeSWCLK SWDIO_Out = iob_7; _StrobeSWCLK}//-----------------------------------------------------------------------------// SW_ShiftByteIn//-----------------------------------------------------------------------------//// Shifts an 8-bit byte in from the SWDIO pin.//// Returns:// 8-bit byte value shifted in on SWDIO.//// Uses:// io_byte - Holds byte as it is shifted in.//#pragma OT(8, SPEED)U8 SW_ShiftByteIn( void ){ // Make sure SWDIO is an input _SetSWDIOasInput; // Shift 8-bits in on SWDIO iob_0 = SWDIO_In; _StrobeSWCLK iob_1 = SWDIO_In; _StrobeSWCLK iob_2 = SWDIO_In; _StrobeSWCLK iob_3 = SWDIO_In; _StrobeSWCLK iob_4 = SWDIO_In; _StrobeSWCLK iob_5 = SWDIO_In; _StrobeSWCLK iob_6 = SWDIO_In; _StrobeSWCLK iob_7 = SWDIO_In; _StrobeSWCLK // Return the byte that was shifted in return io_byte;}

 

//// Copyright (c) 2013 SILICON LABORATORIES, INC.//// FILE NAME   : main.c// TARGET MCU  : C8051F380// DESCRIPTION : ARM Debug Interface for a 32-bit Programmer//// This program demonstrates the basic Serial Wire interface functionality.// It does not include the procedures to write, erase, or read flash.//// NOTES:// 1) Remove J15 from the 'F38x Target Board.// 2) Connect SWDIO (P1.1), SWCLK (P1.3), and ground to the 10-pin CoreSight//    connector of an SiM3U/C/L.// 3) Run the code and observe that transfer_data contains the correct IDCODE//    to validate the SW interface.////#include 
#include
#include "32bit_prog_defs.h"#include "Init.h"#include "bin_array.h"//-----------------------------------------------------------------------------// Variables Declarations//-----------------------------------------------------------------------------// Debug Port (DP) type. Tracks the type of the current DP connection.U8 DP_Type;// Possible values for DP_Type.enum{ DP_TYPE_NONE, DP_TYPE_SWD};// Cortex M3 Debug Registers (AHB addresses)#define DDFSR 0xE000ED30 // Debug Fault StatusRegister#define DHCSR 0xE000EDF0 // Debug Halting Control and Status Register#define DCRSR 0xE000EDF4 // Debug Core Register Selector Register#define DCRDR 0xE000EDF8 // Debug Core Register Data Register#define DEMCR 0xE000EDFC // Debug Exception and Monitor Control Register#define AIRCR 0xE000ED0C // The Application Interrupt and Reset Control Register// Cortex M3 Memory Access Port#define MEMAP_BANK_0 0x00000000 // BANK 0 => CSW, TAR, Reserved, DRW#define MEMAP_BANK_1 0x00000010 // BANK 1 => BD0, BD1, BD2, BD3// SiM3 Chip Access Port (SiLabs specific Debug Access Port)#define CHIPAP_BANK_0 0x0A000000 // BANK 0 => CTRL1, CTRL2, LOCK, CRC#define CHIPAP_BANK_1 0x0A000010 // BANK 1 => INIT_STAT, DAP_IN, DAP_OUT, None#define CHIPAP_BANK_F 0x0A0000F0 // BANK F => None, None, None, ID// MEMAP register addresses#define MEMAP_CSW 0x01#define MEMAP_TAR 0x05#define MEMAP_DRW_WR 0x0D#define MEMAP_DRW_RD 0x0F// CHIPAP register addresses#define CHIPAP_CTRL1_WR 0x01#define CHIPAP_CTRL2_WR 0x05#define CHIPAP_ID_WR 0x0D#define CHIPAP_ID_RD 0x0F#ifdef SRAM_PROGRAMMINGvoid connect_and_halt_core(){ U32 rw_data; rw_data = CHIPAP_BANK_F; SWD_DAP_Move(0, DAP_SELECT_WR, &rw_data); SWD_DAP_Move(0, CHIPAP_ID_RD, &rw_data); if (rw_data != 0x2430002) { return; } // CTRL1.core_reset_ap = 1 rw_data = CHIPAP_BANK_0; SWD_DAP_Move(0, DAP_SELECT_WR, &rw_data); rw_data = 0x08; SWD_DAP_Move(0, CHIPAP_CTRL1_WR, &rw_data); // Select MEM BANK 0 rw_data = MEMAP_BANK_0; SWD_DAP_Move(0, DAP_SELECT_WR, &rw_data); // 32 bit memory access, auto increment rw_data = 0x23000002; SWD_DAP_Move(0, MEMAP_CSW, &rw_data); // DHCSR.C_DEBUGEN = 1 rw_data = DHCSR; SWD_DAP_Move(0, MEMAP_TAR, &rw_data); rw_data = 0xA05F0001; SWD_DAP_Move(0, MEMAP_DRW_WR, &rw_data); // DEMCR.VC_CORERESET = 1 rw_data = DEMCR; SWD_DAP_Move(0, MEMAP_TAR, &rw_data); rw_data = 0x1; SWD_DAP_Move(0, MEMAP_DRW_WR, &rw_data); // reset the core rw_data = AIRCR; SWD_DAP_Move(0, MEMAP_TAR, &rw_data); rw_data = 0xFA050004; SWD_DAP_Move(0, MEMAP_DRW_WR, &rw_data); // CTRL1.core_reset_ap = 0 rw_data = CHIPAP_BANK_0; SWD_DAP_Move(0, DAP_SELECT_WR, &rw_data); rw_data = 0; SWD_DAP_Move(0, CHIPAP_CTRL1_WR, &rw_data); // Select MEM BANK 0 rw_data = MEMAP_BANK_0; SWD_DAP_Move(0, DAP_SELECT_WR, &rw_data);}void write_sequential_words(U32 addr, U32 len, U32 *rw_data){ U32 i, tmp; U32 *buf = rw_data; tmp = MEMAP_BANK_0; SWD_DAP_Move(0, DAP_SELECT_WR, &tmp); // 32 bit memory access, auto increment tmp = 0x23000012; SWD_DAP_Move(0, MEMAP_CSW, &tmp); SWD_DAP_Move(0, MEMAP_TAR, &addr); for (i = 0; i < len; i++) { SWD_DAP_Move(0, MEMAP_DRW_WR, buf++); }}void read_sequential_words(U32 addr, U32 len, U32 *rw_data){ U32 i, tmp; U32 *buf = rw_data; tmp = MEMAP_BANK_0; SWD_DAP_Move(0, DAP_SELECT_WR, &tmp); // 32 bit memory access, auto increment tmp = 0x23000012; SWD_DAP_Move(0, MEMAP_CSW, &tmp); SWD_DAP_Move(0, MEMAP_TAR, &addr); for (i = 0; i < len; i++) { SWD_DAP_Move(0, MEMAP_DRW_RD, buf++); }}void swd_write_core_register(U32 n, U32 *rw_data){ U32 tmp; tmp = MEMAP_BANK_0; SWD_DAP_Move(0, DAP_SELECT_WR, &tmp); tmp = 0x23000002; SWD_DAP_Move(0, MEMAP_CSW, &tmp); tmp = DCRDR; SWD_DAP_Move(0, MEMAP_TAR, &tmp); SWD_DAP_Move(0, MEMAP_DRW_WR, rw_data); tmp = DCRSR; SWD_DAP_Move(0, MEMAP_TAR, &tmp); n = n | (0x10000); SWD_DAP_Move(0, MEMAP_DRW_WR, &n);}void swd_read_core_register(U32 n, U32 *rw_data){ U32 tmp; tmp = MEMAP_BANK_0; SWD_DAP_Move(0, DAP_SELECT_WR, &tmp); tmp = 0x23000002; SWD_DAP_Move(0, MEMAP_CSW, &tmp); tmp = DCRSR; SWD_DAP_Move(0, MEMAP_TAR, &tmp); SWD_DAP_Move(0, MEMAP_DRW_WR, &n); tmp = DCRDR; SWD_DAP_Move(0, MEMAP_TAR, &tmp); SWD_DAP_Move(0, MEMAP_DRW_RD, rw_data);}void programming_sram(){ U32 i, size, count, addr = 0x20000000; size = sizeof(binraw) / 4; for (i = 0; i < size; i += 1024) { if ((i + 1024) < size) { count = 1024; } else { count = size - i; } write_sequential_words(addr + i * 4, count, &binraw[i]); } write_sequential_words(0xe000ed08, 1, &addr); addr = binraw[1] & 0xFFFFFFFE; swd_write_core_register(15, &addr); addr = binraw[0]; swd_write_core_register(13, &addr); addr = 0xA05F0000; write_sequential_words(DHCSR, 1, &addr);}#endif//-----------------------------------------------------------------------------// main()//-----------------------------------------------------------------------------void main( void ){ U32 transfer_data; WDT_Init( ); Oscillator_Init( ); Port_Init( ); // These pins are grounded on the CoreSight debug connector P1_4 = 0; P1_2 = 0; // There is no debug port connection at this point DP_Type = DP_TYPE_NONE; SWD_Initialize( ); SWD_Configure( DP_TYPE_SWD ); SWD_Connect( ); transfer_data = 0x00000000; // Read the IDCODE from the connected device SWD_DAP_Move( 0, DAP_IDCODE_RD, &transfer_data ); // The return value from DAP_IDCODE_RD for SiM3U1xx devices is 0x2BA01477 // Write the CTRLSTAT register to enable the debug hardware transfer_data = 0x50000000; SWD_DAP_Move( 0, DAP_CTRLSTAT_WR, &transfer_data ); SWD_ClearErrors( ); connect_and_halt_core( ); programming_sram( ); transfer_data = 0x00000000; SWD_DAP_Move( 0, DAP_CTRLSTAT_WR, &transfer_data ); SWD_Disconnect( ); while ( 1 ) { }}//-----------------------------------------------------------------------------// Initialization//-----------------------------------------------------------------------------//-----------------------------------------------------------------------------// Subroutines//-----------------------------------------------------------------------------//-----------------------------------------------------------------------------// DBG_Reset//-----------------------------------------------------------------------------//// This function returns all debug pins to a neutral state:// 1. Disconnects from the target.// 2. Resets all I/O pins.////void DBG_Reset( void ){ SWD_Connect( ); // Reset all I/O ports Port_Init( ); // We are disconnecting, so release nSRST _ReleaseTargetReset;}

 

转载地址:http://lnrhx.baihongyu.com/

你可能感兴趣的文章
java方法重载
查看>>
[Redis]Redis的设计与实现-链表/字典/跳跃表
查看>>
python装饰器(decorator)两种模式探讨集合
查看>>
高级 DO 语法
查看>>
kafka生产消息的速度跟什么有关?
查看>>
Web API 简介
查看>>
Jexus下配置多个站点
查看>>
mysql case when * else end
查看>>
C#中==与Equals方法的区别
查看>>
「珍藏」老司机为你推荐10个炫酷的开源库,看完的人都收藏了
查看>>
Xcode编辑器的技巧与诀窍
查看>>
String、StringBuffer与StringBuilder之间区别
查看>>
工作第十三周:身体掏空,精神饱满
查看>>
Linux 内核--任务0的运行(切换到用户模式)move_to_user_mode
查看>>
ios扩展机制objc_setAssociatedObject,objc_getAssociatedObject
查看>>
批量添加-fno-objc-arc
查看>>
二叉树的层序遍历
查看>>
os模块
查看>>
安装 matplotlib
查看>>
css伪类(:before和:after)
查看>>