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 #![no_std] support #64

Merged
merged 46 commits into from
Sep 11, 2024
Merged

Conversation

overcat
Copy link
Contributor

@overcat overcat commented Sep 1, 2024

What

add #![no_std] support.

Why

Allow it to work on embedded devices (such as STM32).

Known limitations

N/A

Cargo.toml Outdated Show resolved Hide resolved
@leighmcculloch leighmcculloch self-requested a review September 2, 2024 01:25
@leighmcculloch leighmcculloch self-assigned this Sep 2, 2024
Copy link
Member

@leighmcculloch leighmcculloch left a comment

Choose a reason for hiding this comment

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

Can we explore making the crate noalloc? I think it makes for a much bigger case for supporting nostd and was what we were hoping to do. I think because of the functionality in the crate, that the size of what is being enc/dec is always predictable, this should be possible. Although I don't know how well the data-encoding crate is at supporting that. Wdyt?

Cargo.toml Show resolved Hide resolved
@overcat overcat marked this pull request as draft September 5, 2024 16:14
@overcat
Copy link
Contributor Author

overcat commented Sep 5, 2024

Hi @leighmcculloch, I have initially added support for no alloc, the current implementation is quite rough, and I will improve it tomorrow. It would be great if you could review the interface, but please do not focus on the details of the implementation at this time.

@overcat overcat marked this pull request as ready for review September 6, 2024 04:49
leighmcculloch added a commit that referenced this pull request Sep 8, 2024
Remove the thiserror crate and replace with the same code that would be
generated.

This change was authored by @overcat in #64, and has been extracted to commit
separately.

Co-authored-by: Jun Luo <[email protected]>
Copy link
Member

@leighmcculloch leighmcculloch left a comment

Choose a reason for hiding this comment

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

@overcat Thanks for taking a look at what it would take to make this go no-alloc and for the time you put into it ❤️.

In interest of getting the no-std functionality you need merged asap you should revert the last few no-alloc commits, because looking back at it the no-std change is on its own much more surgical and easier to review, and makes no breaking changes to the API.

The no-alloc change as proposed requires breaking changes to the API that I'd like some more time to think about, but I don't want to delay getting a no-std version out.

Thanks for persevering with me on this, I didn't realize scope difference of the no-alloc vs no-std approach.

.github/workflows/rust.yml Outdated Show resolved Hide resolved
Cargo.toml Outdated Show resolved Hide resolved
README.md Outdated Show resolved Hide resolved
leighmcculloch added a commit that referenced this pull request Sep 10, 2024
Remove the thiserror crate and replace with the same code that would be
generated.

This change was authored by @overcat in #64, and has been extracted to commit
separately.

Co-authored-by: Jun Luo <[email protected]>
@leighmcculloch
Copy link
Member

@overcat Can you merge main into this PR?

@overcat
Copy link
Contributor Author

overcat commented Sep 11, 2024

Hi @leighmcculloch, the current CI is failing, I think it's due to the Action cache, but I don't have permission to clear the cache.

I wrote the wrong command for updating the Rust version.

CI passed.

Copy link
Member

@leighmcculloch leighmcculloch left a comment

Choose a reason for hiding this comment

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

Two small changes requested inline, otherwise this looks great.

.github/workflows/rust.yml Show resolved Hide resolved
Cargo.toml Show resolved Hide resolved
README.md Outdated Show resolved Hide resolved
tests/tests.rs Outdated
@@ -1,8 +1,10 @@
use stellar_strkey::*;
#![no_std]
Copy link
Member

Choose a reason for hiding this comment

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

Tests always run with std imported anyway, because the test framework itself uses std, so I don't think we need the changes in this file.

Is there a reason using alloc explicitly here benefits?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yes, you are right, I have removed it.

But I am curious if we should add a test to see if it works properly under no std? It seems that there are some testing frameworks that can achieve this: https://github.com/knurling-rs/defmt

Copy link
Member

Choose a reason for hiding this comment

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

We could add a crate to the repo that imports strkey and gets built as part of testing, that provides it's own panic handler, because the only way it'll build is if std isn't imported because there can't be two panic handler and std provides one.

https://doc.rust-lang.org/nomicon/panic-handler.html

Copy link
Member

@leighmcculloch leighmcculloch Sep 11, 2024

Choose a reason for hiding this comment

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

On the same note that's a lot of test machinery for checking something that is unlikely to be the case since the no_std attribute is in use.

The risk is that it depends on a crate that pulls in std, but we're unlikely to add new deps to this repo.

I wonder if something like https://github.com/cackle-rs/cackle could detect it.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Hi @leighmcculloch, I have integrated version 0.0.11 into Ledger, and it's working very well. Currently, I want to make rs-stellar-xdr support no std, so I will work on the tests here and consider adding no alloc support in my free time.

Copy link
Member

@leighmcculloch leighmcculloch Sep 11, 2024

Choose a reason for hiding this comment

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

There's nothing riding on no alloc, so if it's not of value to you, I suggest holding off as there's nothing that I know of needing it right now.

@leighmcculloch leighmcculloch changed the title feat: add #![no_std] support. Add #![no_std] support Sep 11, 2024
@leighmcculloch leighmcculloch merged commit 311bd2b into stellar:main Sep 11, 2024
5 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants