summaryrefslogtreecommitdiff
path: root/gnss/common/utils/default/DeviceFileReader.cpp
diff options
context:
space:
mode:
authorMatt Lee <matthewhlee@google.com>2023-06-09 14:22:50 -0700
committerMatt Lee <matthewhlee@google.com>2023-06-09 14:22:50 -0700
commitf772fa8736319cf9cd92b6df11ff5409c4ab7e52 (patch)
tree90440ebec891f481da400afd777c5543e662d415 /gnss/common/utils/default/DeviceFileReader.cpp
parent90e555a5038f8749fa5f720c4285193ee437a7c1 (diff)
parent9ac16c42d3722424277f971e9a44a99e6ee1679d (diff)
Merge t-qpr-2023-06
Change-Id: Ib4c3576a60b830ea540dc4aef3e01bd2ad0c0db2
Diffstat (limited to 'gnss/common/utils/default/DeviceFileReader.cpp')
-rw-r--r--gnss/common/utils/default/DeviceFileReader.cpp44
1 files changed, 28 insertions, 16 deletions
diff --git a/gnss/common/utils/default/DeviceFileReader.cpp b/gnss/common/utils/default/DeviceFileReader.cpp
index dfc086a8b8..91e75eb460 100644
--- a/gnss/common/utils/default/DeviceFileReader.cpp
+++ b/gnss/common/utils/default/DeviceFileReader.cpp
@@ -32,40 +32,52 @@ void DeviceFileReader::getDataFromDeviceFile(const std::string& command, int mMi
return;
}
- int mGnssFd = open(deviceFilePath.c_str(), O_RDWR | O_NONBLOCK);
-
- if (mGnssFd == -1) {
+ int gnss_fd, epoll_fd;
+ if ((gnss_fd = open(deviceFilePath.c_str(), O_RDWR | O_NONBLOCK)) == -1) {
+ return;
+ }
+ if (write(gnss_fd, command.c_str(), command.size()) <= 0) {
+ close(gnss_fd);
return;
}
- int bytes_write = write(mGnssFd, command.c_str(), command.size());
- if (bytes_write <= 0) {
- close(mGnssFd);
+ // Create an epoll instance.
+ if ((epoll_fd = epoll_create1(EPOLL_CLOEXEC)) < 0) {
+ close(gnss_fd);
return;
}
+ // Add file descriptor to epoll instance.
struct epoll_event ev, events[1];
- ev.data.fd = mGnssFd;
+ memset(&ev, 0, sizeof(ev));
+ ev.data.fd = gnss_fd;
ev.events = EPOLLIN;
- int epoll_fd = epoll_create1(0);
- epoll_ctl(epoll_fd, EPOLL_CTL_ADD, mGnssFd, &ev);
- int bytes_read = -1;
- std::string inputStr = "";
- int epoll_ret = epoll_wait(epoll_fd, events, 1, mMinIntervalMs);
+ if (epoll_ctl(epoll_fd, EPOLL_CTL_ADD, gnss_fd, &ev) == -1) {
+ close(gnss_fd);
+ close(epoll_fd);
+ return;
+ }
- if (epoll_ret == -1) {
- close(mGnssFd);
+ // Wait for device file event.
+ if (epoll_wait(epoll_fd, events, 1, mMinIntervalMs) == -1) {
+ close(gnss_fd);
+ close(epoll_fd);
return;
}
+
+ // Handle event and write data to string buffer.
+ int bytes_read = -1;
+ std::string inputStr = "";
while (true) {
memset(inputBuffer, 0, INPUT_BUFFER_SIZE);
- bytes_read = read(mGnssFd, &inputBuffer, INPUT_BUFFER_SIZE);
+ bytes_read = read(gnss_fd, &inputBuffer, INPUT_BUFFER_SIZE);
if (bytes_read <= 0) {
break;
}
s_buffer_ += std::string(inputBuffer, bytes_read);
}
- close(mGnssFd);
+ close(gnss_fd);
+ close(epoll_fd);
// Trim end of file mark(\n\n\n\n).
auto pos = s_buffer_.find("\n\n\n\n");