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

drivers: lora: Make the SX1276 driver independent of loramac module #22535

Closed
KubaFYI opened this issue Feb 6, 2020 · 5 comments
Closed

drivers: lora: Make the SX1276 driver independent of loramac module #22535

KubaFYI opened this issue Feb 6, 2020 · 5 comments
Labels
RFC Request For Comments: want input from the community

Comments

@KubaFYI
Copy link
Contributor

KubaFYI commented Feb 6, 2020

Problem description

The Semtech sx1276 driver currently selects the incomplete loramac-node module to be built with it. This is unnecessary as users might wish to use just the driver without the entire LoRaMAC stack. Besides, currently the loramac-node contains it's own duplicate of the sx1276 driver code which is confusing.

Proposed change

Make it so that loramac-node (through HAS_SEMTECH_LORAMAC) requires the sx1276 driver and not the other way around.

@KubaFYI KubaFYI added the RFC Request For Comments: want input from the community label Feb 6, 2020
@KubaFYI
Copy link
Contributor Author

KubaFYI commented Feb 6, 2020

@Mani-Sadhasivam could you please let me know if that makes sense?

@Mani-Sadhasivam
Copy link
Member

@KubaFYI The SX1276 driver in Zephyr is a shim driver for the one available in loramac-node repo. During my first attempt to add LoRa support, I made the SX1276 independent of the LoRAMAC stack but that was NACKed and folks asked me to use the existing work available in loramac-node. Hence, I came up with this shim driver for Zephyr.

So the Zephyr SX1276 driver should depend on the loramac-node repo. Your proposed change won't work as loramac-node repo doesn't have any dependency with Zephyr.

@KubaFYI
Copy link
Contributor Author

KubaFYI commented Feb 6, 2020

Thanks, understood.

May I ask what's the rationale behind taking the entirety of loramac-node code and including it as a module rather than porting it as a driver + library? I'm in a process of building a Lorawan node on zephyr and I'm trying to understand what's the best way for me to go forward.

@Mani-Sadhasivam
Copy link
Member

May I ask what's the rationale behind taking the entirety of loramac-node code and including it as a module rather than porting it as a driver + library?

I'm not sure if I understand your question. Currently loramac-node is built as a library. Not all the configurations in the loramac-node is enabled atm. You can look here.

I'm in a process of building a Lorawan node on zephyr and I'm trying to understand what's the best way for me to go forward.

Cool. I'm also working on LoRAWAN support in parallel. Let me know if you want to join the effort.

@KubaFYI
Copy link
Contributor Author

KubaFYI commented Feb 6, 2020

I'm not sure if I understand your question.

I suppose I meant why is it a module instead of just cherry-picked files put in zephyr/lib and zephyr/drivers/lora, but that just comes from me not being that familiar with zephyr's build process and project structure.

Cool. I'm also working on LoRAWAN support in parallel. Let me know if you want to join the effort.

Grand, I'll ping you an email.

@KubaFYI KubaFYI closed this as completed Feb 6, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
RFC Request For Comments: want input from the community
Projects
None yet
Development

No branches or pull requests

2 participants