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

sensor: Introduce Phosense XBR818 Driver #81013

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

VynDragon
Copy link
Contributor

@VynDragon VynDragon commented Nov 6, 2024

This Introduces a driver for the i2c interface of Phosense XBR818.
XBR818 is a 10.525Ghz Radar chip with in-built movement detection algorithm.

Copy link
Contributor

@jilaypandya jilaypandya left a comment

Choose a reason for hiding this comment

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

drivers/sensor/xbr818/xbr818.c Outdated Show resolved Hide resolved
drivers/sensor/xbr818/xbr818.c Outdated Show resolved Hide resolved
drivers/sensor/xbr818/xbr818.c Show resolved Hide resolved
drivers/sensor/xbr818/xbr818.c Show resolved Hide resolved
drivers/sensor/xbr818/xbr818.c Outdated Show resolved Hide resolved
dts/bindings/sensor/phosense,xbr818.yaml Outdated Show resolved Hide resolved
@VynDragon
Copy link
Contributor Author

VynDragon commented Nov 7, 2024

add an entry to the build_all test https://github.com/zephyrproject-rtos/zephyr/blob/main/tests/drivers/build_all/sensor/i2c.dtsi

Addressed all the comments, can you confirm what i've added to i2c.dtsi is correct? Thanks.

Edit: I'm not sure what is causing the build failure, the changes I made shouldn't affect this, unless unknown vendor prefix breaks the test (which it shouldnt do knowing the majority of vendors are not in that list and i was told it's only a copy of the linux one, so we cant add to it).

@jilaypandya
Copy link
Contributor

(which it shouldnt do knowing the majority of vendors are not in that list and i was told it's only a copy of the linux one, so we cant add to it)

Try adding the vendor name over here
https://github.com/zephyrproject-rtos/zephyr/blob/main/dts/bindings/vendor-prefixes.txt

@VynDragon
Copy link
Contributor Author

Try adding the vendor name over here https://github.com/zephyrproject-rtos/zephyr/blob/main/dts/bindings/vendor-prefixes.txt

Done, but I am concerned it isn't fine, though maybe I misunderstand something.

@VynDragon
Copy link
Contributor Author

check error now is relevant to additional sensor attributes, not sure what to do given this is a pattern that exists in other drivers, maybe I am not doing it how it's supposed to be?
image
image

@jilaypandya
Copy link
Contributor

jilaypandya commented Nov 14, 2024

give it a try with parenthesis

#define foo (SENSOR_ATTR_PRIV_START + 1 )

Copy link
Contributor

@jilaypandya jilaypandya left a comment

Choose a reason for hiding this comment

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

I believe you need to refactor the files in drivers/sensor/<vendor_name>/

@VynDragon
Copy link
Contributor Author

I believe you need to refactor the files in drivers/sensor/<vendor_name>/

I dont think so, looks to be only if there is more than one sensor of the vendor (eg sensor/bosch folder vs sensor/mhz19b or sensor/hp206c for example)

@VynDragon
Copy link
Contributor Author

VynDragon commented Nov 15, 2024

Found a couple more cases of variable possibly spending longer time on stack than needed so i removed the init at 0 for them too.

jilaypandya
jilaypandya previously approved these changes Dec 20, 2024
rruuaanng
rruuaanng previously approved these changes Jan 9, 2025

i2c-en-gpios:
type: phandle-array
required: true
Copy link
Collaborator

Choose a reason for hiding this comment

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

Making this required might be overly restrictive. I believe it's quite common that people who might not care all that much about e.g. power consumption would wire things so that I2C is always enabled. Code would need updating so that only when pin has been configured it's being toggled, otherwise assume always on. See e.g. https://github.com/zephyrproject-rtos/zephyr/blob/main/drivers/haptics/drv2605.c#L550-L559

That being said, I'm counting on other sensor collaborators to confirm whether what I'm saying makes sense :)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

It makes sense, I didnt consider the possibility of always on, only always off where my thought was 'no driver needed in that case'.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Done.

Comment on lines 70 to 105
ret = gpio_pin_set_dt(&config->i2c_en, 1);
if (ret != 0) {
LOG_ERR("%s: could not set i2c_en pin", dev->name);
}
Copy link
Collaborator

Choose a reason for hiding this comment

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

you may want to extract all these i2c-enable / i2c-disable in an (inline?) function to avoid duplication

what's more, looking at what seems to be some kind of reference implementation (given the datasheet is really not that helpful...), I wonder if you want to add 10us delay to be on the safe side? https://github.com/Ai-Thinker-Open/STM32F102_Rd-04/blob/master/Rd-04/rd_04_driver.c#L109-L110

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Done (?).

Copy link
Collaborator

Choose a reason for hiding this comment

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

answering to your question mark with this from the Contribution guidelines :)

Best way is to basically leave the conversation "unresolved" so that the person who request/suggested the change can go back and provide further feedback / eventually resolve the comment. This is also a good way for reviewer to not have to keep mental notes of all the things they may have asked in the past and that they need to go and double check, as it's really hard to do once all conversations have already been resolved and are collasped in the Github UI

Copy link
Collaborator

Choose a reason for hiding this comment

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

so... unresolving until I have another look :) and even if the conversation doesn't get "resolved" in Github, that deosn't prevent reviewer to eventually give a +1 anyway

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Alright, I'll leave the conversations open in the future.

tests/drivers/build_all/sensor/i2c.dtsi Outdated Show resolved Hide resolved
dts/bindings/sensor/phosense,xbr818.yaml Outdated Show resolved Hide resolved
drivers/sensor/xbr818/xbr818.h Outdated Show resolved Hide resolved
Comment on lines 15 to 18
#define SENSOR_ATTR_XBR818_DELAY_TIME (SENSOR_ATTR_PRIV_START)
#define SENSOR_ATTR_XBR818_LOCK_TIME (SENSOR_ATTR_PRIV_START + 1)
#define SENSOR_ATTR_XBR818_NOISE_FLOOR (SENSOR_ATTR_PRIV_START + 2)
#define SENSOR_ATTR_XBR818_RF_POWER (SENSOR_ATTR_PRIV_START + 3)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Those need to be in a public header file, which this file isn't, if you want people to be able to use this :) i.e. they need to be moved to a include/zephyr/drivers/sensor/xbr818.h header.
Also please make sure this has proper Doxygen comments. See e.g. https://github.com/zephyrproject-rtos/zephyr/blob/main/include/zephyr/drivers/sensor/tmag5273.h#L36-L49

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Done.

Copy link
Collaborator

Choose a reason for hiding this comment

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

Also please make sure this has proper Doxygen comments.

Can you please take another pass, as Doxygen comments are missing (see, a good reason for not closing conversations after all 😉 ).
https://builds.zephyrproject.io/zephyr/pr/81013/docs/doxygen/html/xbr818_8h.html#a2f524848967d71fe6c7557355a064bec
you want something like tmag5273.h that I pointed you to, where the enum and all its fields have proper doxygen comments. (

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Then I have not properly identified what constitute a proper doxygen comment, what is it? the /** instead of /* at the start?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Ok, figured it out.

@VynDragon
Copy link
Contributor Author

Rebased on latest main.

kartben
kartben previously approved these changes Jan 20, 2025
@VynDragon
Copy link
Contributor Author

Rebased on latest main.

yperess
yperess previously approved these changes Jan 27, 2025
Copy link
Collaborator

@yperess yperess left a comment

Choose a reason for hiding this comment

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

Only nits, I'm OK if you choose to ignore them. Seems fine to me.

if (ret < 0) {
return ret;
}
data->value = (ret == 1 ? true : false);
Copy link
Collaborator

Choose a reason for hiding this comment

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

nit, why not just data->value = rent == 1;?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I do prefer the ternary form.

const struct xbr818_config *config = dev->config;
int ret;

ret = i2c_reg_write_byte_dt(&config->i2c, XBR818_IO_ACTIVE_VALUE_REG, 0x03);
Copy link
Collaborator

Choose a reason for hiding this comment

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

nit: This is a lot of branches. Generally if one fails we can't recover anyway. I usually like to do:

int ret = 0;

ret |= i2c_*(...);
__ASSERT(ret == 0, "Some error message);

ret |= i2c_*(...);
__ASSERT(ret == 0, "Some error message);

return ret;

This way when I build a debug build I enable the asserts and I can see exactly when something fails, but in production I just care if the function failed and the asserts turn into no-ops.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

This is nice, done.

This Introduces a driver for the i2c interface of Phosense XBR818.
XBR818 is a 10.525Ghz Radar chip with builtin detection algorithm.

Signed-off-by: Camille BAUD <[email protected]>
@VynDragon
Copy link
Contributor Author

Rebased on latest main.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants