-
Notifications
You must be signed in to change notification settings - Fork 47
/
Copy pathpio_jtag.h
60 lines (41 loc) · 1.84 KB
/
pio_jtag.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#ifndef _PIO_JTAG_H
#define _PIO_JTAG_H
#include "hardware/pio.h"
typedef struct pio_jtag_inst {
PIO pio;
uint sm;
uint pin_tdi;
uint pin_tdo;
uint pin_tck;
uint pin_tms;
uint pin_rst;
uint pin_trst;
} pio_jtag_inst_t;
void init_jtag(pio_jtag_inst_t* jtag, uint freq, uint pin_tck, uint pin_tdi, uint pin_tdo, uint pin_tms, uint pin_rst, uint pin_trst);
void pio_jtag_write_blocking(const pio_jtag_inst_t *jtag, const uint8_t *src, size_t len);
void pio_jtag_write_read_blocking(const pio_jtag_inst_t *jtag, const uint8_t *src, uint8_t *dst, size_t len);
uint8_t pio_jtag_write_tms_blocking(const pio_jtag_inst_t *jtag, bool tdi, bool tms, size_t len);
void jtag_set_clk_freq(const pio_jtag_inst_t *jtag, uint freq_khz);
void jtag_transfer(const pio_jtag_inst_t *jtag, uint32_t length, const uint8_t* in, uint8_t* out);
uint8_t jtag_strobe(const pio_jtag_inst_t *jtag, uint32_t length, bool tms, bool tdi);
static inline void jtag_set_tms(const pio_jtag_inst_t *jtag, bool value)
{
gpio_put(jtag->pin_tms, value);
}
static inline void jtag_set_rst(const pio_jtag_inst_t *jtag, bool value)
{
/* Change the direction to out to drive pin to 0 or to in to emulate open drain */
gpio_set_dir(jtag->pin_rst, !value);
}
static inline void jtag_set_trst(const pio_jtag_inst_t *jtag, bool value)
{
gpio_put(jtag->pin_trst, value);
}
// The following APIs assume that they are called in the following order:
// jtag_set_XXX where XXX is any pin. if XXX is clk it needs to be false
// jtag_set_clk where clk is true This will initiate a one cycle pio_jtag_write_read_blocking
// possibly jtag_get_tdo which will get what was read during the previous step
void jtag_set_tdi(const pio_jtag_inst_t *jtag, bool value);
void jtag_set_clk(const pio_jtag_inst_t *jtag, bool value);
bool jtag_get_tdo(const pio_jtag_inst_t *jtag);
#endif