-
Notifications
You must be signed in to change notification settings - Fork 89
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Windows11: OpenOCD from MSDK cannot initialize the MAX32625PICO CMSIS-DAP #1251
Comments
@rhempel I can confirm that our toolchain should work on Windows 11. I have been using on my home machine successfully. The error log seems like permission issues on the USB port. You will need USB read/write access on the machine to connect to the PICO. I suspect IT has locked this on your managed machine. If you can write a file to a USB drive you should have equivalent permissions to connect to the PICO. The "could not open device" messages are standard as OpenOCD iterates across all the USB devices it can find. The device ID for the PICO is They key errors in your log are
|
Thanks for the reply @Jake-Carter - I believe it does have something to do with permissions, but it's not read/write permissions on the USB drive. I have an IT-exception for this on my machine, and I can confirm that I am able to create, read, and modify files on the exposed USB drive for both the DAPLINK and MAINTENANCE modes of the PICO. I understand how the enumeration scan works for OpenOCD and have looked at the AD fork of the source. Is there a possibility of adding some additional diagnostic output for the -v option when OpenOCD tries an operation on the 0x0d28:0x0204 device? The enumeration works so there is some other operation failing when it tries to add it to the list of valid CMSIS-DAP devices. By the way, the command line I am using to open the device is:
I can see in your log that cmsis_dap.c functions are getting called, and that's missing on my side. Is there an additional driver/dll that OpenOCD needs to work on Windows11? |
The main difference is that I am missing:
The WebUSB driver I have is slightly different: The Details.txt contents on my PICO are:
|
I have opened a ticket with our IT provider - there are some posts on the web that indicate CrowdStrike may be interfering with some USB endpoint devices. This kind of makes sense, so I'll follow up on this when I hear back ... |
Still no update from out IT staff ... |
@Jake-Carter UPDATE: I have looked more closely at the startup logs and there IS one difference - your product string does not match the one I am getting from my PICO. Here is what I get:
and you have this in your log
The product string does not match, which means my MAX32625PICO probably has different firmware than yours. Would you be able to point me to a link for the firmware in your PICO? |
@Jake-Carter - just a follow up, would you be able to point me to a link for the firmware in your PICO? None of the images PICO firmware repository give the USB Product string in the logs you have shared :-) |
@Jake-Carter - ping? |
@Jake-Carter Here is a little more information from the USB Device Tree Viewer V4.4.3 running on my Crowdstrike Falcon protected laptop. It looks like the HID descriptor is failing the read operation, which kind of explains why the PICO is not staying on the list of devices that can be opened by OpenOCD
The F1 Help offers this:
|
SOLVED! This turned out to be a lot of digging around and finally stumbling on the solution ... As an embedded developer I have to support devices from multiple vendors - and that sometimes means installing vendor specific tools and drivers. In this case, I had an old vendor specific CMSIS-DAP v1 driver on my laptop, and this was causing the AD/MAX PICO to pick up the wrong driver. The fix is relatively simple. Go into Device Manager on your Windows machine and choose "View By Driver". The look for ANY and ALL drivers with CMSIS or DAP in the name, right click, and then choose "Remove Driver" When you have deleted all of them (and you may have dozens if not hundreds of .inf files) then plug in your MAX32625 PICO and you will be able to use OpenOCD to detect and use the device. Sometimes you have to keep chewing on the bone ... |
On my corporate managed Windows11 laptop, the OpenOCD from the MSDK installer will not open the MAX32625PICO CMSIS-DAP device.
On the same laptop, a VirtualBox VM that we attach the same PICO to as a USB device will work under OpenOCD and PyOCD
At this point I'm not sure if it's a general Windows 11 issue, or if it has to do with the corporate management of USB devices - long story short is I can't do any work with the MAX32690FTHR board until this is working.
I can work around it using a Linux laptop but ideally I would like to use a standard (if somewhat locked down) Windows11 device.
Debug: 87 298 semihosting_common.c:109 semihosting_common_init(): Debug: 88 345 cmsis_dap_usb_bulk.c:105 cmsis_dap_usb_open(): could not open device 0x2109:0x0813: Operation not supported or unimplemented on this platform Debug: 89 345 cmsis_dap_usb_bulk.c:105 cmsis_dap_usb_open(): could not open device 0x27c6:0x63ac: Access denied (insufficient permissions) Debug: 90 345 cmsis_dap_usb_bulk.c:105 cmsis_dap_usb_open(): could not open device 0x8087:0x0033: Operation not supported or unimplemented on this platform Debug: 91 361 cmsis_dap_usb_bulk.c:105 cmsis_dap_usb_open(): could not open device 0x8086:0x51ed: Operation not supported or unimplemented on this platform Debug: 92 361 cmsis_dap_usb_bulk.c:150 cmsis_dap_usb_open(): found product string of 0x0d28:0x0204 'DAPLink CMSIS-DAP' Debug: 93 371 cmsis_dap_usb_bulk.c:170 cmsis_dap_usb_open(): enumerating interfaces of 0x0d28:0x0204 Debug: 94 377 cmsis_dap_usb_bulk.c:237 cmsis_dap_usb_open(): skipping interface 0, endpoint[0] is not bulk out Debug: 95 377 cmsis_dap_usb_bulk.c:230 cmsis_dap_usb_open(): skipping interface 1, has only 1 endpoints Debug: 96 377 cmsis_dap_usb_bulk.c:276 cmsis_dap_usb_open(): skipping interface 2, class 10 subclass 0 protocol 0 Debug: 97 377 cmsis_dap_usb_bulk.c:217 cmsis_dap_usb_open(): found interface 3 string 'CMSIS-DAP v1' Debug: 98 393 cmsis_dap_usb_bulk.c:237 cmsis_dap_usb_open(): skipping interface 3, endpoint[0] is not bulk out Debug: 99 393 cmsis_dap_usb_bulk.c:217 cmsis_dap_usb_open(): found interface 4 string 'WebUSB: CMSIS-DAP' Debug: 100 393 cmsis_dap_usb_bulk.c:230 cmsis_dap_usb_open(): skipping interface 4, has only 0 endpoints Debug: 101 393 cmsis_dap_usb_bulk.c:105 cmsis_dap_usb_open(): could not open device 0x0c45:0x6d1f: Entity not found Debug: 102 408 cmsis_dap_usb_bulk.c:105 cmsis_dap_usb_open(): could not open device 0x8086:0x461e: Operation not supported or unimplemented on this platform Debug: 103 408 cmsis_dap_usb_bulk.c:105 cmsis_dap_usb_open(): could not open device 0x2109:0x2813: Operation not supported or unimplemented on this platform Debug: 104 408 cmsis_dap_usb_bulk.c:105 cmsis_dap_usb_open(): could not open device 0x0b95:0x1790: Operation not supported or unimplemented on this platform Error: 105 424 cmsis_dap.c:293 cmsis_dap_open(): unable to find a matching CMSIS-DAP device Debug: 106 424 command.c:544 run_command(): Command 'init' failed with error code -4
The text was updated successfully, but these errors were encountered: