sensor_rpmsg.c: Fix that "stub" will be created when local core only has subscribers.

After the ap core subscribes to the 25hz batch 120ms data of the sensor core, it switches
to the cp core and subscribes to the 50hz batch 120ms sensor core data. At this time,
the data subscribed by the AP will be abnormally lost (12.5hz). Mainly because ap
subscribes to sensor core data earlier than cp. The subscription of cp will be broadcast
to the ap core at the same time, and the corresponding "path" already exists
under "/dev/uorb" of ap. Thus the ap will create a "stub".

There are some restrictions on the creation of "stub" to avoid this situation.

Signed-off-by: likun17 <likun17@xiaomi.com>
This commit is contained in:
likun17 2024-03-08 16:35:51 +08:00 committed by Xiang Xiao
parent 112cc083d3
commit bdac8c116a

View File

@ -1049,7 +1049,7 @@ static int sensor_rpmsg_sub_handler(FAR struct rpmsg_endpoint *ept,
int ret; int ret;
dev = sensor_rpmsg_find_dev(msg->path); dev = sensor_rpmsg_find_dev(msg->path);
if (!dev) if (!dev || (dev->nadvertisers == 0 && !dev->lower.persist))
{ {
return 0; return 0;
} }