<gamiee>
Hmm, this is strange. I have JLink connected to the target. When I use JLink server, it probes the chip just fine (Cortex M33). But when I use OpenOCD, it manages to get DPIDR (which is right), but afterwards, Examination failed, with often different error message, which looks like signal integrity issue? But why same connection, same JLink works just good with JLInk Server....
<gamiee>
(what is even more strange, when using FTDI with SWD resistor hack, it's also not always stable, but it's capable of examination of the chip properly and also debug the target... with same TCL config... I am super confused)
<zapb__>
gamiee, what target is it? There should be no difference between OpenOCD and JLink server wrt signal integrity etc.
<gamiee>
zapb__ : hi! Sorry, I can't disclose yet, but anyway, there are absolutely 0 information online about the chip. Just it uses ARM Cortex M33 core, made by ARM China.
<gamiee>
and exactly, it does not give any sense :/
<PaulFertser>
Probably the adapter speed is different?
<PaulFertser>
Fastest way would be to check the signals with oscilloscope.
<zapb__>
Well yes, maybe the default speed is different
noarb has quit [Ping timeout: 252 seconds]
Haohmaru has joined #openocd
<gamiee>
PaulFertser: actually, on JLink Server, it was 4000 Hz, on OpenOCD only 200 Hz. But I tried 4000 Hz on OpenOCD as well, but that did not helped as well.
<gamiee>
So yeah, even on slower speed than JLink Server, it did not worked. That's why I am super confused. And yeah, I plan to check it out on logic analyzer.
merethan has quit [Remote host closed the connection]
merethan has joined #openocd
<Haohmaru>
are you sure that's Hz and not kHz?
<Haohmaru>
200Hz is like a high-pitch fart
en-sc has joined #openocd
Guest72 has joined #openocd
Guest72 has quit [Client Quit]
<gamiee>
Haohmaru oops... Yeah, brainfart. I guess every number I used/told is kHz, sorry
<Haohmaru>
and, you say with jlink alone (this thing makes a gdb server itself, thus no openocd involved) it "works" (so this CPUID is nonzero), but when openocd pulls the ropes of the jlink you get the above ^
<Haohmaru>
if the jlink doesn't do anything different in general with the actual SWD (like different pin drive strength, or pull resistors, something of this sort), then i'd think a possible difference could be related to timing
<gamiee>
Exactly, that's why I do not get it :/
<Haohmaru>
speed and/or the time between different SWD "packets"
<gamiee>
but even it does not scan all AHB-APs
<Haohmaru>
other possible thing could be the actual sequence of SWD commands (the algorithm of the communication) could differ between jlink alone and openocd->jlink
<Haohmaru>
iirc SWDIO generally should be pulled... up i think
<Haohmaru>
when the SWDIO changes directions there are moments when neither side shall drive it and then it is left to the pull resistor
<Haohmaru>
wait a minute... "AP[0]: Skipped. Invalid implementer code read from CPUIDVal[31:24] = 0x00"
<Haohmaru>
isn't that the same CPUID?
<Haohmaru>
is your mystery MCU a legit one or is it some very early alpha version ;P~
<Haohmaru>
if you scan it with a very fancy X-RAY microscope, are there a lot of "/* TODO */" inbetween the transistors ;P~
<gamiee>
Ohh, nice catch from JLink log. Ummm, well , I do not know :D :D :D (to other side, this is dual core MCU) it's mystery for me as well. (I even don't have the chip, I am doing stuff remotely)
<Haohmaru>
like "/* TODO: this should return a CPUID that we haven't registered yet, so for now we return zeros */"
<Haohmaru>
because to my nose it seems openocd just quits further operations when CPUID turns out to be 0x0 and it doesn't recognize wtf this is
<Haohmaru>
not sure if the list of known "CPUID" values is something hardcoded into openocd, or whether you can override it (or specify a custom CPUID value) in a config, but if it's possible you could try fooling openocd that 0x0 _is_ the "right" value for this MCU and then maybe openocd would continue forward with the operations
<gamiee>
Bingo!
<gamiee>
I need to specify -ap-num to "1"
<Haohmaru>
mmm, the name of this is familiar but i forgot what it was for
<gamiee>
CPUID is specified in OpenOCD
<gamiee>
there are known vendors of ARM cores. This one is from ARM China
<Haohmaru>
yeah i'm almost sure openocd probably might have a map/LUT of a bunch of basic CPUIDs, but i would maybe thing this could be overridden either via commands or configs
<Haohmaru>
e.g. you can tell avrdude to ignore the "deviceID" of a chip and continue with the commands
<Haohmaru>
this can happen if something is not quite right but it could still work as long as avrdude pretends that things are okay
<gamiee>
heh
<gamiee>
now it makes sense
<gamiee>
for some reason, CPU0 is halted, so I can't access it, that's why AP0 is having CPUID 0x0
<Haohmaru>
oh
<Haohmaru>
the two cores have individual debug stuff that work independantly?
<Haohmaru>
or well, i wouldn't understand it even if someone tells me, ignore this question
<Haohmaru>
if the problem is solved - good ;P~
<gamiee>
I do not know how this exactly works either. But yeah.
<gamiee>
So basically, JLink worked only because it automatically switched to next AP
<gamiee>
Haohmaru : thank you for rubberduck debugging, I appreciate it.
<Haohmaru>
kool
defiant has quit [Quit: defiant]
en-sc has quit [Remote host closed the connection]
en-sc has joined #openocd
<karlp>
gamiee: I remember adding a part number for some arm china stuff before, there might be more to add.
<karlp>
yeah, src/target/arm.h, arm_implementer
<karlp>
PaulFertser: did we turn off gitweb on gerrit? was there meant to be some other path to browse source?
<karlp>
meh, back to openocd.org to source forge is ok I guess.
<Haohmaru>
is the vendor literally called "ARM China" o_O
<karlp>
that's.... their name?
<karlp>
did you miss the whole arm vs arm china shit?
wmat has left #openocd [#openocd]
<Haohmaru>
when, where?
<Haohmaru>
i guess "yes"
<gamiee>
karlp : No need, it was identified properly it's just STAR-MC1
en-sc has quit [Remote host closed the connection]
en-sc has joined #openocd
<PaulFertser>
karlp: yes, gitweb was contributing to Gerrit being slow sometimes.
<karlp>
np, just couldn't figure out what I was missing :)
en-sc has quit [Remote host closed the connection]
en-sc has joined #openocd
Haohmaru has quit [Quit: saionara]
Hawk777 has joined #openocd
noarb has joined #openocd
en-sc has quit [Remote host closed the connection]
Hawk777 has quit [Quit: Leaving.]
Hawk777 has joined #openocd
nerozero has quit [Ping timeout: 260 seconds]
tchebb has joined #openocd
tchebb_ has quit [Ping timeout: 265 seconds]
<antto>
does anyone happen to know how to build a firmware for a daplink?
<antto>
i was trying to see if i can rebuild the firmware for this kamami zl33prg, which i *think* is very similar to SWDAP or DIPDAP (it uses lpc11u35 and has SWD and UART)
<antto>
i followed the build instructions, got entangled in snek scripts, and uhm, i tried building "lpc11u35_if", a firmware .bin was generated, but i have no idea if this is the right thing or not
<antto>
when searching for "lpc11u35" there are too many results all over the daplink projects (many in those yaml files and i can't figure out wtf's going on)