- replaced JLINK_xxxx command defines by EMU_CMD_ from the

J-Link USB Protocol specification
- added functionality to jlink_init to display the version.

git-svn-id: svn://svn.berlios.de/openocd/trunk@675 b42882b7-edfa-0310-969c-e2dbd0fdcd60
This commit is contained in:
mifi 2008-05-24 07:11:18 +00:00
parent 155c3d763c
commit 209112000b
1 changed files with 58 additions and 27 deletions

View File

@ -59,16 +59,19 @@ static u8 usb_in_buffer[JLINK_IN_BUFFER_SIZE];
static u8 usb_out_buffer[JLINK_OUT_BUFFER_SIZE]; static u8 usb_out_buffer[JLINK_OUT_BUFFER_SIZE];
/* Constants for JLink command */ /* Constants for JLink command */
#define JLINK_FIRMWARE_VERSION 0x01
#define JLINK_SPEED_COMMAND 0x05 /* The JLINK_TAP_SEQUENCE_COMMAND is obsolete *
#define JLINK_GET_STATUS_COMMAND 0x07 /* and we should use EMU_CMD_HW_JTAG instead */
#define JLINK_TAP_SEQUENCE_COMMAND 0xcd #define JLINK_TAP_SEQUENCE_COMMAND 0xcd
#define JLINK_GET_SERIAL 0xe6
#define JLINK_SET_SRST_LOW_COMMAND 0xdc #define EMU_CMD_VERSION 0x01
#define JLINK_SET_SRST_HIGH_COMMAND 0xdd #define EMU_CMD_SET_SPEED 0x05
#define JLINK_SET_TRST_LOW_COMMAND 0xde #define EMU_CMD_GET_STATE 0x07
#define JLINK_SET_TRST_HIGH_COMMAND 0xdf #define EMU_CMD_HW_JTAG 0xcf
#define JLINK_HARDWARE_VERSION 0xe8 #define EMU_CMD_HW_RESET0 0xdc
#define EMU_CMD_HW_RESET1 0xdd
#define EMU_CMD_HW_TRST0 0xde
#define EMU_CMD_HW_TRST1 0xdf
/* max speed 12MHz v5.0 jlink */ /* max speed 12MHz v5.0 jlink */
#define JLINK_MAX_SPEED 12000 #define JLINK_MAX_SPEED 12000
@ -244,7 +247,7 @@ int jlink_speed(int speed)
if (speed == 0) if (speed == 0)
speed = -1; speed = -1;
usb_out_buffer[0] = JLINK_SPEED_COMMAND; usb_out_buffer[0] = EMU_CMD_SET_SPEED;
usb_out_buffer[1] = (speed >> 0) & 0xff; usb_out_buffer[1] = (speed >> 0) & 0xff;
usb_out_buffer[2] = (speed >> 8) & 0xff; usb_out_buffer[2] = (speed >> 8) & 0xff;
@ -285,6 +288,8 @@ int jlink_register_commands(struct command_context_s *cmd_ctx)
int jlink_init(void) int jlink_init(void)
{ {
int result; int result;
int len;
int check_cnt;
jlink_jtag_handle = jlink_usb_open(); jlink_jtag_handle = jlink_usb_open();
@ -294,8 +299,37 @@ int jlink_init(void)
return ERROR_JTAG_INIT_FAILED; return ERROR_JTAG_INIT_FAILED;
} }
check_cnt = 0;
while (check_cnt < 3)
{
/* query hardware version */
jlink_simple_command(EMU_CMD_VERSION);
result = jlink_usb_read(jlink_jtag_handle); result = jlink_usb_read(jlink_jtag_handle);
if (result != 2 || usb_in_buffer[0] != 0x07 || usb_in_buffer[1] != 0x00)
if (result == 2)
{
/* Get length */
len = buf_get_u32(usb_in_buffer, 0, 16);
/* Get version */
result = jlink_usb_read(jlink_jtag_handle);
if(result == len)
{
usb_in_buffer[result] = 0;
LOG_INFO(usb_in_buffer);
/* attempt to get status */
jlink_get_status();
break;
}
}
check_cnt++;
}
if (check_cnt == 3)
{ {
LOG_INFO("J-Link initial read failed, don't worry"); LOG_INFO("J-Link initial read failed, don't worry");
} }
@ -305,9 +339,6 @@ int jlink_init(void)
jlink_reset(0, 0); jlink_reset(0, 0);
jlink_tap_init(); jlink_tap_init();
/* query jlink status */
jlink_get_status();
return ERROR_OK; return ERROR_OK;
} }
@ -437,20 +468,20 @@ void jlink_reset(int trst, int srst)
/* Signals are active low */ /* Signals are active low */
if (trst == 0) if (trst == 0)
{ {
jlink_simple_command(JLINK_SET_TRST_HIGH_COMMAND); jlink_simple_command(EMU_CMD_HW_TRST1);
} }
else if (trst == 1) else if (trst == 1)
{ {
jlink_simple_command(JLINK_SET_TRST_LOW_COMMAND); jlink_simple_command(EMU_CMD_HW_TRST0);
} }
if (srst == 0) if (srst == 0)
{ {
jlink_simple_command(JLINK_SET_SRST_HIGH_COMMAND); jlink_simple_command(EMU_CMD_HW_RESET1);
} }
else if (srst == 1) else if (srst == 1)
{ {
jlink_simple_command(JLINK_SET_SRST_LOW_COMMAND); jlink_simple_command(EMU_CMD_HW_RESET0);
} }
} }
@ -473,7 +504,7 @@ int jlink_get_status(void)
{ {
int result; int result;
jlink_simple_command(JLINK_GET_STATUS_COMMAND); jlink_simple_command(EMU_CMD_GET_STATE);
result = jlink_usb_read(jlink_jtag_handle); result = jlink_usb_read(jlink_jtag_handle);
if(result == 8) if(result == 8)
@ -491,7 +522,7 @@ int jlink_get_status(void)
} }
else else
{ {
LOG_ERROR("J-Link command JLINK_GET_STATUS_COMMAND failed (%d)\n", result); LOG_ERROR("J-Link command EMU_CMD_GET_STATE failed (%d)\n", result);
} }
return ERROR_OK; return ERROR_OK;
@ -503,7 +534,7 @@ int jlink_handle_jlink_info_command(struct command_context_s *cmd_ctx, char *cmd
int len = 0; int len = 0;
/* query hardware version */ /* query hardware version */
jlink_simple_command(JLINK_FIRMWARE_VERSION); jlink_simple_command(EMU_CMD_VERSION);
result = jlink_usb_read(jlink_jtag_handle); result = jlink_usb_read(jlink_jtag_handle);
if (result == 2) if (result == 2)
@ -522,7 +553,7 @@ int jlink_handle_jlink_info_command(struct command_context_s *cmd_ctx, char *cmd
} }
else else
{ {
LOG_ERROR("J-Link command JLINK_FIRMWARE_VERSION failed (%d)\n", result); LOG_ERROR("J-Link command EMU_CMD_VERSION failed (%d)\n", result);
} }
return ERROR_OK; return ERROR_OK;