JTAG_host.c源码
时间: 2024-03-28 11:38:30 浏览: 102
以下是一个简单的JTAG主机(JTAG_host.c)的示例代码,用于通过JTAG接口与目标设备进行通信。
```c
#include <stdio.h>
#include <stdint.h>
#define TCK 0x01 // JTAG时钟线
#define TMS 0x02 // JTAG状态线
#define TDI 0x04 // JTAG数据输入线
#define TDO 0x08 // JTAG数据输出线
void jtag_init(void);
void jtag_shift_ir(uint8_t *data, uint32_t count);
void jtag_shift_dr(uint8_t *data_in, uint8_t *data_out, uint32_t count);
int main(void) {
uint8_t ir_data[4] = {0x3, 0x2, 0x1, 0x0};
uint8_t dr_data_in[16] = {0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xAA, 0xBB, 0xCC, 0xDD, 0xEE, 0xFF};
uint8_t dr_data_out[16] = {0};
jtag_init();
// 将IR移位
jtag_shift_ir(ir_data, 4);
// 将DR移位
jtag_shift_dr(dr_data_in, dr_data_out, 16);
return 0;
}
void jtag_init(void) {
// 初始化JTAG接口
// ...
}
void jtag_shift_ir(uint8_t *data, uint32_t count) {
uint32_t i;
uint8_t bit;
// 将TMS线拉高
// ...
for (i = 0; i < count; i++) {
// 将TDI线写入IR位
bit = (data[i] >> 0) & 0x01;
// ...
bit = (data[i] >> 1) & 0x01;
// ...
bit = (data[i] >> 2) & 0x01;
// ...
bit = (data[i] >> 3) & 0x01;
// ...
// 将TMS线拉低
// ...
// 将TMS线拉高
// ...
}
// 最后一位TMS线拉高
// ...
}
void jtag_shift_dr(uint8_t *data_in, uint8_t *data_out, uint32_t count) {
uint32_t i;
uint8_t bit_in, bit_out;
// 将TMS线拉高
// ...
for (i = 0; i < count; i++) {
// 将TDI线写入DR位并读取TDO线
bit_in = (data_in[i] >> 0) & 0x01;
// ...
bit_out = read_tdo();
data_out[i] |= (bit_out << 0);
bit_in = (data_in[i] >> 1) & 0x01;
// ...
bit_out = read_tdo();
data_out[i] |= (bit_out << 1);
bit_in = (data_in[i] >> 2) & 0x01;
// ...
bit_out = read_tdo();
data_out[i] |= (bit_out << 2);
bit_in = (data_in[i] >> 3) & 0x01;
// ...
bit_out = read_tdo();
data_out[i] |= (bit_out << 3);
// 将TMS线拉低
// ...
// 将TMS线拉高
// ...
}
// 最后一位TMS线拉高
// ...
}
```
请注意,此示例代码仅提供了一个基本的JTAG通信框架。实际使用时,您需要根据您的目标设备和应用程序的需求进行必要的修改和扩展。
阅读全文