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

Add embassy microcontroller example demonstrating async #7064

Open
wants to merge 9 commits into
base: master
Choose a base branch
from

Conversation

ninjasource
Copy link

An async demo using Embassy and an embedded stm32u5g9j-dk2 development kit. This demonstrates a method to use async in Slint with a microcontroller. The simulator can run on a PC if you do not have the dev kit on hand but it is not meant to be a reference design for an async GUI implementation on a PC.

@CLAassistant
Copy link

CLAassistant commented Dec 11, 2024

CLA assistant check
All committers have signed the CLA.

@ogoffart ogoffart added the need triaging Issue that the owner of the area still need to triage label Dec 12, 2024
@ninjasource
Copy link
Author

Hi, I have given this PR some thought and decided that adding the Slint copyright notice in the Cargo.toml file (or elsewhere) is problematic for my use case as I use this example as the basis of my commercial projects and it is not appropriate to have to include this notice in them. Transferring copyright means that I am exposing myself to risk in other projects as a result. Therefore I would like to retract my signing of the digital CLA contract yesterday and retract this pull request. I’m really sorry to have to do this and I understand the need for your project to have a CLA and copyright notices but it is just not compatible with my risk level. There are no easy answers here and I hope you understand. If Slint really wants an embassy example they are welcome to link to my repository. Also, the Embassy project is so fluid that referencing it from Slint via git revision numbers may be too weak for your stability goals at this time. Keep up the great work!

@tronical
Copy link
Member

Hi David! I'm sorry to hear that, but I understand. Thanks for your clear communication. Yes, linking to your repository is a good idea. I'll take a look to see how we can retract the CLA signature.

@tronical
Copy link
Member

Regarding, the signature, @ninjasource , I think that you can go to https://cla-assistant.io/my-cla and revoke it from there.

@tronical
Copy link
Member

FWIW, I haven't looked at the diff yet - that was still on my TODO. I'll abstain from doing that, and I hope that perhaps we can implement an embassy example ourselves in the future.

@ninjasource
Copy link
Author

Thanks for understanding and thanks for the link. I have a suggestion for demo projects like this that don’t include changes to the core codebase. Perhaps Slint can host a repository that simply links to various open source projects that use Slint.

Something like this as an example: https://github.com/rust-embedded/awesome-embedded-rust

That list is super easy to add to and fairly easy to do housekeeping on for the occasional repos that get taken offline. The Slint team won’t have the arduous task of keeping old demos alive and they will also get insights on how Slint is actually being used in the wild.

@ogoffart
Copy link
Member

Thanks for submitting the PR.

Note that the CLA does not imply copyright transfer. It simply license your code to us under the MIT-0 license.

Now, the CI does indeed check that all files have a license and the test are a bit strict as it force a copyright to Slint which is not needed. So we'd need to fix our CI to allow 3rd party copyright holder. (Which we should have done before as this is not the first time the problem comes up)

I do think having an embassy example would be a great addition in the repository.
Would you be open to keep the PR if we fix our CI to accept less strict copyright lines?

@ninjasource
Copy link
Author

ninjasource commented Dec 17, 2024

Hi @ogoffart,

Yes I would be open to keeping the PR and I am glad that you think it will be a great addition to the Repository!

"Note that the CLA does not imply copyright transfer. It simply license your code to us under the MIT-0 license."

Great, that makes sense, I'm happy with that.

"So we'd need to fix our CI to allow 3rd party copyright holder."

That sounds like a good solution. I would even be open to removing copyright notices on example code but that is up to you guys. I was just uncomfortable with the possibility of losing access to something I had written and use in other projects.

@tronical
Copy link
Member

tronical commented Jan 2, 2025

Hi @ninjasource . We just landed #7260 that should permit the copyright notice. Could you rebase your PR or would you mind if I do?

examples/mcu-embassy/Cargo.toml Outdated Show resolved Hide resolved
examples/mcu-embassy/Cargo.toml Outdated Show resolved Hide resolved
@ninjasource
Copy link
Author

ninjasource commented Jan 8, 2025

I have spent several hours trying to figure out why the build is breaking with:

error: failed to select a version for `embassy-time-driver`

I suspect it has something to do with referencing git dependencies and caching but I'm a little stumped. Copying the mcu-embassy folder out of the workspace and running it independently of the slint project resolves the issue so that may hint at what is wrong.

@tronical
Copy link
Member

tronical commented Jan 8, 2025

It looks like the problem is that within the Slint cargo workspace, esp-hal's support for some boards also pulls in that embassy time driver, in a different version. And despite targeting entirely different boards/configurations, it's this "safeguard" that causes this:

https://github.com/embassy-rs/embassy/blob/6ec108232e14cfab817848a8772cf095a6a44642/embassy-time-driver/Cargo.toml#L17

esp32-s2/s3 support seems to enable usb-otg, which I think is what pulls in embassy: https://github.com/esp-rs/esp-hal/blob/6b4312fb905f6cc356cedc07547cab09c92535da/esp-hal/Cargo.toml#L120

For now, one easy workaround for this issue is to take this example out of the Cargo workspace. I've posted a one-liner suggestion how this looks like. That way it compiles for me.

Comment on lines +398 to +399
- name: Check
run: cargo check -p mcu_embassy --bin ui_mcu --target=thumbv8m.main-none-eabihf --no-default-features --features="mcu-embassy/mcu" --release
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For reasons I don't quite understand, the CI didn't run on the latest. But I ran it manually and noticed this error:

error: cannot specify features for packages outside of workspace

I tried locally, could reproduce it, and I think this is the easy fix:

Suggested change
- name: Check
run: cargo check -p mcu_embassy --bin ui_mcu --target=thumbv8m.main-none-eabihf --no-default-features --features="mcu-embassy/mcu" --release
- name: Check
working-directory: examples/mcu-embassy
run: cargo check --bin ui_mcu --target=thumbv8m.main-none-eabihf --no-default-features --features="mcu-embassy/mcu" --release

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
need triaging Issue that the owner of the area still need to triage
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants