/**************************************************************************** * apps/system/uorb/sensor/topics.c * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. The * ASF licenses this file to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance with the * License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. * ****************************************************************************/ /**************************************************************************** * Included Files ****************************************************************************/ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include /**************************************************************************** * Private Data ****************************************************************************/ static FAR const struct orb_metadata *g_sensor_list[] = { ORB_ID(sensor_accel), ORB_ID(sensor_accel_uncal), ORB_ID(sensor_baro), ORB_ID(sensor_cap), ORB_ID(sensor_co2), ORB_ID(sensor_dust), ORB_ID(sensor_ecg), ORB_ID(sensor_force), ORB_ID(sensor_gps), ORB_ID(sensor_gps_satellite), ORB_ID(sensor_gyro), ORB_ID(sensor_gyro_uncal), ORB_ID(sensor_hall), ORB_ID(sensor_hbeat), ORB_ID(sensor_hcho), ORB_ID(sensor_humi), ORB_ID(sensor_hrate), ORB_ID(sensor_impd), ORB_ID(sensor_ir), ORB_ID(sensor_light), ORB_ID(sensor_light_uncal), ORB_ID(sensor_mag), ORB_ID(sensor_mag_uncal), ORB_ID(sensor_noise), ORB_ID(sensor_ots), ORB_ID(sensor_ph), ORB_ID(sensor_pm10), ORB_ID(sensor_pm1p0), ORB_ID(sensor_pm25), ORB_ID(sensor_ppgd), ORB_ID(sensor_ppgq), ORB_ID(sensor_prox), ORB_ID(sensor_rgb), ORB_ID(sensor_temp), ORB_ID(sensor_tvoc), ORB_ID(sensor_uv), ORB_ID(sensor_wake_gesture), ORB_ID(sensor_wake_gesture_uncal), NULL, }; /**************************************************************************** * Public Functions ****************************************************************************/ FAR const struct orb_metadata *orb_get_meta(FAR const char *name) { struct sensor_state_s state; char path[ORB_PATH_MAX]; int idx = -1; int ret; int fd; int i; /* Fisrt search built-in topics */ for (i = 0; g_sensor_list[i]; i++) { size_t len = strlen(g_sensor_list[i]->o_name); if ((!strncmp(g_sensor_list[i]->o_name, name, len)) && (name[len] == '\0' || isdigit(name[len]))) { idx = i; break; } } if (idx != -1) { return g_sensor_list[idx]; } /* Then open node to get meta */ snprintf(path, ORB_PATH_MAX, ORB_SENSOR_PATH"%s", name); fd = open(path, O_RDONLY); if (fd < 0) { snprintf(path, ORB_PATH_MAX, ORB_SENSOR_PATH"%s%d", name, 0); fd = open(path, O_RDONLY); if (fd < 0) { return NULL; } } ret = ioctl(fd, SNIOC_GET_STATE, (unsigned long)(uintptr_t)&state); close(fd); if (ret < 0) { return NULL; } return state.priv; }