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

Allow customization of transmit and receive buffer sizes for I2C 'Wire' and 'Wire1' objects. #149

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

Conversation

dac1e
Copy link

@dac1e dac1e commented Jan 3, 2025

This pull request for the SAM architecture corresponds to pull request #589 for the AVR architecture.

When I had the need for a bigger Wire buffer, I came up with this implementation.

  • Existing sketches work like before, but just with one additional macro in the sketch, Wire will get smaller or larger buffers and will omit unnecessary buffers when possible. E.g. the receive buffer will be omitted when no receive is required. There are six example sketches available, that demonstrate how the macro works and give evidence about the customization of the buffer sizes.
    Wire buffers are still allocated at compile time.

  • Both TwoWire objects Wire and Wire1 are supported.

  • There is also some refactoring done in regard to using C++ casts instead of C casts, making some functions inline for speed and code size.

dac1e added 3 commits January 3, 2025 18:34
Wire and Wire1 use WireBuffer.
Use size_t in for loop instead of uin8_t.
Added override specifier where applicable.
Changed const to constexpr where possible.
Added const qualifiers where possible.
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.

1 participant