Skip to content
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

bmp enhancements; swo support #20

Open
mubes opened this issue Feb 16, 2018 · 10 comments
Open

bmp enhancements; swo support #20

mubes opened this issue Feb 16, 2018 · 10 comments
Assignees

Comments

@mubes
Copy link

mubes commented Feb 16, 2018

Would it be possible for you to add swo support for the bmp? The code to do this is relatively straightforward (See https://github.com/mubes/orbuculum/blob/master/Src/orbuculum.c around line 1202 ... there may be other stuff in Orbuculum you can make use of too) but does need to be enabled via a suitable monitor command (monitor traceswo for 'standard' bmp monitor traceswo <speed> for bluepill or bmp with async swo support). When parallel trace support is in place this will probably be enabled by a similar mechanism.

@Marus
Copy link
Owner

Marus commented Feb 16, 2018

This is on my radar. From the description on the BMP wiki it doesn't sound too difficult for the basic logic (although I haven't looked into the actual code of it, either for Orbuculum or the example linked on the wiki, because of the licensing issues; although I have been reading your blog with great interest). Unfortunately it is a bit more difficult than it would appear because of the Visual Studio Code environment.

The need to do raw access to the USB device, via libusb, presents some difficulty. The JavaScript environment for extensions causes issues as it doesn't naturally expose direct access to USB devices (like it does for Network sockets or file access, used for J-Link and OpenOCD respectively). While I can in theory add binary modules for extending the capabilities (as I have done for the serial port mode) - I haven't yet been able to build a libusb module that is compatible with the VS Code environment. Once I have that roadblock sorted out, then I will likely work on adding native support for SWO from BMP (at least on platforms where I am able to get the module built).

@mubes
Copy link
Author

mubes commented Feb 16, 2018 via email

@Marus Marus self-assigned this Feb 26, 2018
@Marus
Copy link
Owner

Marus commented Feb 26, 2018

I did make some progress on this item - but isn't ready for release yet.

Was able to get the binary module I need for VS Code compiling (at least on Linux and OS X; haven't figured it out for Windows).

Still running into some issues with getting the data off the device reliably. Not sure if it is an issue with the library, or a mistake in how I'm trying to use it (haven't done much with USB programming on either host or device side, so need to look into it more).

If for example - I try to read 64 bytes off of the end point with a timeout of 100 milliseconds (particular values don't actually matter) - if at least 64 bytes were available then they get read off the device and processed properly. If the full 64 bytes weren't available then whatever data should have been collected seems to disappear completely and will never be received.

Since I can't predict the exact speed that data will be available I run into problems (if I try to read faster than it is available it seems to disappear, but can't go slower than it is available as obviously buffers will fill up).

Don't know if you encountered anything like that in your work?

@korken89
Copy link

Hi, the SWO support is now officially in the BMP, and having access to this would be really good!
Instructions for the SWO: https://github.com/blacksphere/blackmagic/blob/master/UsingSWO

I have hardware and can test if there are additions that need testing.

@perlindgren
Copy link

Looking forward to SWO support for the BMP, this could be useful both in our research projects and in education (where we promote vscode + cortex debug). Overall impressions from the students are good, BMP might be another step forward.

@mubes
Copy link
Author

mubes commented Jun 28, 2018 via email

@Marus
Copy link
Owner

Marus commented Jun 28, 2018

I have been working on this, but currently I'm running into an issue with the libusb library for node where I'm either getting lost data and/or significantly delayed data. Once I can get past that issue it should be fairly quick to complete. Going to try to have another look at this in the next couple of weeks.

@williamAlhant
Copy link

Hi,
Any progress/updates ?

haneefdm added a commit that referenced this issue Feb 19, 2020
sync with marus master
@adamhun94
Copy link

Hi,
has anyone made it work (native or alternative way)?
I get a "SWO support is not available from the probe when using the BMP GDB server. Disabling SWO." error message.

@mubes
Copy link
Author

mubes commented Jan 27, 2021

Take a look at orbuculum, it'll do what you want. @Marus the code has nowadays be librified so would hopefully be easier to incorporate, and I'd be very happy to see it in there. Opencd and pyocd both have native orbuculum support now (see instructions in the orbuculum readme). bmp always did have.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

6 participants