NishanthMenon changed the topic of #openocd to: this is the place to discuss all things OpenOCD | Logs: https://libera.irclog.whitequark.org/openocd/
bencoh has quit [Ping timeout: 260 seconds]
bencoh has joined #openocd
bencoh has quit [Ping timeout: 244 seconds]
bencoh has joined #openocd
bencoh has quit [Ping timeout: 260 seconds]
bencoh has joined #openocd
tsal has quit [Ping timeout: 276 seconds]
tsal has joined #openocd
crabbedhaloablut has joined #openocd
nerozero has joined #openocd
Hawk777 has joined #openocd
Haohmaru has joined #openocd
<gamiee> btw, just as info, I guess I managed to do the best reset mechanism as it is possible to do for the Bouffalo chips.
<gamiee> I just wanted to say that doing this was magnificient experience for me, both writing the reset mechanism and scripts in TCL, but also doing flash bank driver.
<gamiee> Now, I just hope it is all good and will be suitable for upstream :P
<Haohmaru> "QC PASSED"
Hawk777 has quit [Quit: Leaving.]
JakeSays has joined #openocd
JakeSayss has quit [Ping timeout: 260 seconds]
Guest99 has joined #openocd
<Guest99> I use openocd like this: openocd -f interface/jlink.cfg -c "adapter serial 11223344"....
<Guest99> However, I get "Error: invalid subcommand "serial 11223344"
<Guest99> anyidea ?
<Haohmaru> was that intended to set the adapter speed?
<Guest99> I have several JLink connected to this host
<Guest99> I want to select one using its serial number
<Haohmaru> oh, okay
<Haohmaru> what version of openocd are you using?
<PaulFertser> Yes, you need to read the user manual that was installed along with the binary you're running.
<Guest99> ok thanks, it's 0.11.0, you're right I didn't check the version and if the command was present
<Guest99> now I see that's "jlink serial xxxxx", thanks !
<karlp> or update to 0.12... :)
<Haohmaru> ^ +1
<Guest99> yes, I'll update
<Guest99> I usually use jlinksdk to connect and interact with my device. When I run the JLink commander, this is what I get:
<Guest99> # Connecting to target via SWD
<Guest99> # Found SW-DP with ID 0x4C013477
<Guest99> # DPIDR: 0x4C013477
<Guest99> # CoreSight SoC-600 or later (DPv3 detected)
<Guest99> # Detecting available APs
<Guest99> # APSpace base (BASEPTR0): 0x00000000
<Guest99> # APSpace size (DPIDR1.ASIZE): 32-bit (4 GB)
<Guest99> # Top-level ROM table, that describes AP map, found
<Guest99> # Scanning top-level ROM table and nested ones to find APs
<Guest99> # AP[0] (APAddr 0x00010000): APB-AP (IDR: 0x24770006)
<Guest99> # AP[1] (APAddr 0x00020000): AXI-AP (IDR: 0x24770014)
<Guest99> # AP[2] (APAddr 0x00030000): APB-AP (IDR: 0x24770006)
<Guest99> # AP[3] (APAddr 0x00040000): AHB-AP (IDR: 0x24770005)
<Guest99> I'm trying to get the same thing with openocd.
<Guest99> This is what I tried:
<Guest99> swd newdap mychip swd -expected-id 0x4C013477
<Guest99> dap create mychip.dap -chain-position mychip.swd -adiv6
<Guest99> ...
<Guest99> Any idea ?
<Guest99> I might have the config wrong, I'm working on it
<PaulFertser> Guest99: please always use some pastebin if you need to share more than two lines.
<Guest99> ok, sorry, I thought it was short enough
<PaulFertser> Guest99: adiv6 requires current code, even 0.12 is too old for that.
<PaulFertser> And use some exiting config for reference, e.g. tcl/target/ampere_qs_mq.cfg
<Guest99> I built openocd from github
<Guest99> I'll check if it's up-to-date
<PaulFertser> Well, probably 0.12 is actually new enough but I still recommend current HEAD.
<PaulFertser> So use existing config from the same version for reference and use pastebin to show full -d3 output please.
<Guest99> I've build current HEAD. Ok thanks, I'll do that.
<PaulFertser> Guest99: hm, "VTarget = 1.193 V" why is that? It's the jlink measuring VTref input and using that for JTAG/SWD signalling.
<Guest99> target is 1.2V
<Guest99> a log of openocd running on this ampere_qs_mq.cfg target would be helpful
Guest99 has quit [Quit: Client closed]
Guest99 has joined #openocd
<PaulFertser> OK, if it's 1.2 V and your jlink supports that it's correct.
<PaulFertser> Guest99: but "SWD ack not OK: 2 WAIT" looks wrong, it's as if the target is in wrong state. What is it doing at the moment you're trying to connect?
<Guest99> yes, the jlink work with Jlink commander
<Guest99> it's doing nothing, the mcu isn't running
<Guest99> I don't even need to start the cortex_m, I just want to access the mem-ap
<PaulFertser> Guest99: you define the CPU target on default AP0, that is, you omit -ap-num , is that right?
<PaulFertser> Guest99: for that do not define the arm target.
<PaulFertser> Define a mem_ap target on the appropriate AP number instead.
<Guest99> mem_ap are on their ap-num target.
<Guest99> "you define the CPU target on default AP0" -> you mean targets mychip.mcu
<PaulFertser> Hm, I see now you're defining all of them. And they all fail.
<Guest99> yes
<Guest99> I guess I would need to analyze the swd traffic and see what's going on. I don't have enough time for this right now :(
<PaulFertser> Guest99: for adiv6 AP num looks like 0x00010000
<PaulFertser> The lowest 3 digits should be zero
<PaulFertser> Guest99: nope, the problem is above SWD layer.
<PaulFertser> Use numbers from APAddr there, not just 0, 1, 2.
<PaulFertser> Guest99: that is mostly likely going to advance your efforts
<Guest99> that's what I'm trying, my connection to the target just failed, I'll be right back
<PaulFertser> (I figured that from "Invalid AP#" and checking the source code of the validation function, then it became obvious it's the immediate problem in this setup)
<Guest99> ok thanks!
Guest99 has quit [Quit: Client closed]
Guest99 has joined #openocd
<PaulFertser> Guest99: please share new output with correct ap numbers.
<Guest99> It's better: https://pastebin.com/f2ZgQWBy
<Guest99> PaulFertser ^
<Guest99> something strange, If I first run the JLink (and a DORMAT-TO-SWD that I need to run manually) and _then_ openocd, it works perfectly
<Guest99> I'll try to do only the DORMAT-TO-SWD on my side, then run openocd and I'll let you know
<Guest99> ok, the power init of my test script was not good. It now works. Thanks PaulFertser, using ap-num with addresses was the key.
Guest99 has quit [Quit: Client closed]
Guest99 has joined #openocd
<PaulFertser> Guest99: yay!
Guest99 has quit [Quit: Client closed]
<PaulFertser> borneoa___: hm, probably -ap-num parameter and the error "Invalid AP#" is confusing in ADIv6 case where an AP _address_ is expected.
Guest99 has joined #openocd
shoragan has quit [Ping timeout: 252 seconds]
a3f has quit [Ping timeout: 272 seconds]
olerem has quit [Ping timeout: 248 seconds]
Pau has joined #openocd
a3f has joined #openocd
shoragan has joined #openocd
olerem has joined #openocd
Pau has quit [Ping timeout: 240 seconds]
Haohmaru has quit [Quit: saionara]
Guest99 has quit [Ping timeout: 240 seconds]
<borneoa___> PaulFertser: agree. There is another feature of ADIv6 that we do not support in OpenOCD yet, that is AP behind an AP. We will probably need to specify the whole path, e.g. dap_name:@addr_ap1/@addr_ap2/@addr_ap3... Maybe the parameter should be simply -ap and the messages adapted accordingly.
<PaulFertser> borneoa___: I do not have any specific suggestion, just an observation that it was the confusing part here for Guest99. Wasn't obvious to me either till I read the code in question.
<PaulFertser> Probably just more specific error diagnostics for different invalid cases printed by is_ap_num_valid() would be enough?
crabbedhaloablut has quit []
nerozero has quit [Ping timeout: 248 seconds]
zjason`` has quit [Read error: Connection reset by peer]
zjason`` has joined #openocd
balrog has quit [Quit: Bye]
balrog has joined #openocd
balrog has quit [Quit: Bye]
balrog has joined #openocd