<josuah>
Thank you for people in this channel for the inspiration :)
<PaulFertser>
josuah: hey
<PaulFertser>
josuah: yes, the DAP thing is Arm specific, other architectures have their own stuff, e.g. MIPS calls it EJTAG.
<Haohmaru>
altho why do i have the impression that i saw some non-ARM core that uses "SWD" for debug?
<Haohmaru>
or did i imagine it
<PaulFertser>
JTAG TAP is just generic JTAG thing which was made standard for boundary scanning. And then vendors add their own protocols on top of it via OEM instructions.
<PaulFertser>
Haohmaru: SWD is Arm-specific. It's another transport (primary being JTAG) for the Arm Debug Interface.
<Haohmaru>
i know, but i have the impression that i saw something...
<Haohmaru>
maybe i didn't
<PaulFertser>
There's also cJTAG which is TI specific way of tunneling JTAG.
<PaulFertser>
(via two wires)
<Haohmaru>
nah, it wasn't TI, some more obscure vendor
<Haohmaru>
i think maybe it was a RISC-V core
<josuah>
PaulFertser: thank you for cutting the differents topic out of my foggy mind!
<Haohmaru>
also, afaik SWD is supposedly just for cortex-M, right?
<josuah>
Cortex-A and Cortex-R too, no?
<Haohmaru>
i see some cortex-R chips are available here and there, but those probably won't have it?
<josuah>
And even non-CPU targets
<Haohmaru>
the thing with SWD is that it's on less number of pins, which is suitable for "MCU"-grade cores that might have few pins total
<Haohmaru>
but i'd assume that it'd be easier to have faster communication (and full-duplex possibly) on an interface with more pins, something with dedicated IN/OUT signals, like SPI
<Haohmaru>
afaik JTAG has that kind of stuff, so i'd think the bigger cores wouldn't bother with SWD when they got tons of pins and you'd want faster communication with the debugger
<PaulFertser>
Haohmaru: usually IC vendors integrated SWJ "IP" from Arm and that SWJ is capable of using both transports, so no, SWD is available on Cortex-A/R as well usually.
<Haohmaru>
oh?
<PaulFertser>
ADI over JTAG is not full-duplex either, so you gain no speed advantage.
<Haohmaru>
you mean the "hardware" design of the chunk that deals with the debug port has both "JTAG" and "SWD" and then vendor gets both but if they don't have much pins they can make JTAG not usable, or the opposite, but the transistors for the whole thing are all there?
<PaulFertser>
Haohmaru: I haven't seen how exactly that feature is sold, what options are available etc. But if JTAG is supported then SWD is supported too in all cases I've heard of.
<Haohmaru>
ahum
<PaulFertser>
I know some LPC MCUs supported only SWD despite having working JTAG for boundary scan.
<Haohmaru>
well, lots of the SAMx cortex-M0+ cores only have usable "SWD"
<PaulFertser>
Yes, so probably that "IP core" has an SWD-only option.
<Haohmaru>
well, if the JTAG flavor isn't full-duplex, at least if the IN/OUT are on sepparate pins there will be less stupid direction flipping and that kind of stuff, so it'd be a bit easier
<Haohmaru>
and probably the data won't have to be "pulled" in one direction with a resistor, but driven in both logic directions so a faster speed should be less problematic i'd think?
<PaulFertser>
Haohmaru: proper SWD push-pulls everything, no pull resistors involved.
<Haohmaru>
oh, hm
<Haohmaru>
the resistor was just in the turn-around clocks when no side should drive the SWDIO?
<PaulFertser>
Haohmaru: if you mean "the resistor hack" it's to support SWD without having true bidir lines.
<Haohmaru>
nah, they tell you to have a pull-up resistor on SWDIO
<PaulFertser>
Well, that doesn't affect speed, just to have defined state when debug adapter is not connected so it's not floating and not able to do random weird things.
<Haohmaru>
my memory is already foggy it seems ;P~
<Haohmaru>
my samd21_daplink is gathering dust again btw
<josuah>
reading more about OpenOCD manual, this is pure gold!
<josuah>
instead of trying to fix all of the users's problem by hiding the issue (spreading FUD is good to trigger paid support, wink wink SEGGER :P), it gives you tool to investigate
<josuah>
getting anything done in firmware step (1.) debug your debugger ^_^
<Haohmaru>
at first i was happy that there's a relatively cheap "edu" debugger, but then there's that license that doesn't allow you to do this or that.. ugh
<Haohmaru>
and their proper debugger is $$$muchos$$$grande$$$
<Haohmaru>
"hobbyists, gtfo"
<josuah>
That reminds me of some USB3 protocol analyzer where the most affordable one is $3k, and most contractors refrain themselves from getting one as much as possible until really necessary
<Haohmaru>
huh, a "usb debugger" but it's for debugging your actual USB, heh
<josuah>
yeah :D accessing 5 Gbit/s seems more challenging than getting a SWD interface ticking
<josuah>
I like projects that improve the situation and Segger is, huh... not that :]
<josuah>
at least not in low-level troubleshooting
Hawk777 has joined #openocd
Haohmaru has quit [Quit: saionara]
nerozero has quit [Ping timeout: 244 seconds]
pi0 has quit [Ping timeout: 244 seconds]
pi0 has joined #openocd
<karlp>
(m0 is exlicitly swd only, not a samd pecularity)
<karlp>
in other news, I saw an a55 with swd header today. _only_ swdio, swclk and gnd.
<karlp>
no reset, no swo. on a 3pin 2.54mm header no less.