1 // SPDX-License-Identifier: GPL-2.0+
3 * (C) Copyright 2004, Psyent Corporation <www.psyent.com>
4 * Scott McNutt <smcnutt@psyent.com>
14 #define ALTERA_JTAG_RVALID BIT(15) /* Read valid */
16 /* control register */
17 #define ALTERA_JTAG_AC BIT(10) /* activity indicator */
18 #define ALTERA_JTAG_RRDY BIT(12) /* read available */
19 #define ALTERA_JTAG_WSPACE(d) ((d) >> 16) /* Write space avail */
20 /* Write fifo size. FIXME: this should be extracted with sopc2dts */
21 #define ALTERA_JTAG_WRITE_DEPTH 64
23 struct altera_jtaguart_regs
{
24 u32 data
; /* Data register */
25 u32 control
; /* Control register */
28 struct altera_jtaguart_platdata
{
29 struct altera_jtaguart_regs
*regs
;
32 static int altera_jtaguart_setbrg(struct udevice
*dev
, int baudrate
)
37 static int altera_jtaguart_putc(struct udevice
*dev
, const char ch
)
39 struct altera_jtaguart_platdata
*plat
= dev
->platdata
;
40 struct altera_jtaguart_regs
*const regs
= plat
->regs
;
41 u32 st
= readl(®s
->control
);
43 #ifdef CONFIG_ALTERA_JTAG_UART_BYPASS
44 if (!(st
& ALTERA_JTAG_AC
)) /* no connection yet */
48 if (ALTERA_JTAG_WSPACE(st
) == 0)
51 writel(ch
, ®s
->data
);
56 static int altera_jtaguart_pending(struct udevice
*dev
, bool input
)
58 struct altera_jtaguart_platdata
*plat
= dev
->platdata
;
59 struct altera_jtaguart_regs
*const regs
= plat
->regs
;
60 u32 st
= readl(®s
->control
);
63 return st
& ALTERA_JTAG_RRDY
? 1 : 0;
65 return !(ALTERA_JTAG_WSPACE(st
) == ALTERA_JTAG_WRITE_DEPTH
);
68 static int altera_jtaguart_getc(struct udevice
*dev
)
70 struct altera_jtaguart_platdata
*plat
= dev
->platdata
;
71 struct altera_jtaguart_regs
*const regs
= plat
->regs
;
74 val
= readl(®s
->data
);
76 if (!(val
& ALTERA_JTAG_RVALID
))
82 static int altera_jtaguart_probe(struct udevice
*dev
)
84 #ifdef CONFIG_ALTERA_JTAG_UART_BYPASS
85 struct altera_jtaguart_platdata
*plat
= dev
->platdata
;
86 struct altera_jtaguart_regs
*const regs
= plat
->regs
;
88 writel(ALTERA_JTAG_AC
, ®s
->control
); /* clear AC flag */
93 static int altera_jtaguart_ofdata_to_platdata(struct udevice
*dev
)
95 struct altera_jtaguart_platdata
*plat
= dev_get_platdata(dev
);
97 plat
->regs
= map_physmem(devfdt_get_addr(dev
),
98 sizeof(struct altera_jtaguart_regs
),
104 static const struct dm_serial_ops altera_jtaguart_ops
= {
105 .putc
= altera_jtaguart_putc
,
106 .pending
= altera_jtaguart_pending
,
107 .getc
= altera_jtaguart_getc
,
108 .setbrg
= altera_jtaguart_setbrg
,
111 static const struct udevice_id altera_jtaguart_ids
[] = {
112 { .compatible
= "altr,juart-1.0" },
116 U_BOOT_DRIVER(altera_jtaguart
) = {
117 .name
= "altera_jtaguart",
119 .of_match
= altera_jtaguart_ids
,
120 .ofdata_to_platdata
= altera_jtaguart_ofdata_to_platdata
,
121 .platdata_auto_alloc_size
= sizeof(struct altera_jtaguart_platdata
),
122 .probe
= altera_jtaguart_probe
,
123 .ops
= &altera_jtaguart_ops
,
126 #ifdef CONFIG_DEBUG_UART_ALTERA_JTAGUART
128 #include <debug_uart.h>
130 static inline void _debug_uart_init(void)
134 static inline void _debug_uart_putc(int ch
)
136 struct altera_jtaguart_regs
*regs
= (void *)CONFIG_DEBUG_UART_BASE
;
139 u32 st
= readl(®s
->control
);
141 if (ALTERA_JTAG_WSPACE(st
))
145 writel(ch
, ®s
->data
);