Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
Support Arduino SAMD21 #4
base: master
Are you sure you want to change the base?
Support Arduino SAMD21 #4
Changes from all commits
3bca57a
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This change is technically unrelated, but causes the code to not compile for some bords that do not have Serial1.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see SAMD21 is added to the define. I don't have a SAMD21 and thus have not tested. I was looking at https://learn.adafruit.com/using-atsamd21-sercom-to-add-more-spi-i2c-serial-ports/muxing-it-up. It looks that the SAM21D has 6 serial communication options, of which 3 or 4 are already used (depending on the board) : SPI, I2C, Serial and (maybe) debug serial. In the same tutorial (https://learn.adafruit.com/using-atsamd21-sercom-to-add-more-spi-i2c-serial-ports/creating-a-new-serial) it describes what needs to happen to add a serial port. Have you tried that and does that work ?
regards
Paul
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can reassign the SERCOMs and create other serial interfaces too, but you have to declare them yourself (including the IRQ). By default only
Serial
andSerial1
are declared (andSerial2
for the LoRaWAN enabled device). The standard serials are defined in for example: https://github.com/arduino/ArduinoCore-samd/blob/master/variants/mkr1000/variant.cpp#L173-L180 ). That means that, even though users are technically allowed to create more Serial interfaces, we don't know about the existence of these serials at compile time. The only way to support these other serial ports too would probably be through the means of introducing a mechanism of providing a custom Serial/Stream object to the SPS30 object.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks. I had a closer look and I think you can use serial1 without any library change. There is already a special workaround for boards that have serial1 and we can force to use that:
set for Serialport usage:
#define SP30_COMMS SERIALPORT1
Set both RX and TX to 8 : (will force Serail1 port with default pins)
#define TX_PIN 8
#define RX_PIN 8
On a SAM21D it will use pin 0 (RX) and 1 (TX).
On an Arduino these pins are used for USB as well, but not on the SAM21D (serialUSB)
can you try that and let me know that works?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's exactly why I created this port to enable an easier assignment of interfaces. https://github.com/AdvancedClimateSystems/sps30/
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks.
There are indeed different ways to handle the connection. I had chosen to embed it in this library, in other libraries I have taken a different approach. I have tested this library and many different boards, including SAMx1D boards, and have had no problems in getting connected.
Given there are many copies in use around the world, I want to retain the backward compatibility so people do not have to update their sketches when updating the library.