diff options
author | Mark Salyzyn <salyzyn@google.com> | 2016-02-02 09:19:39 -0800 |
---|---|---|
committer | Mark Salyzyn <salyzyn@google.com> | 2016-02-03 15:06:45 -0800 |
commit | e37111d7516827489232c6c894e114a58952fe4a (patch) | |
tree | 197b51e4e57b4963a61b32f05db67f99130544aa /libcutils/ashmem-dev.c | |
parent | 1186f3a5ad6581fae6e284fef4bfcefe50462cda (diff) | |
download | core-e37111d7516827489232c6c894e114a58952fe4a.tar.gz core-e37111d7516827489232c6c894e114a58952fe4a.tar.bz2 core-e37111d7516827489232c6c894e114a58952fe4a.zip |
libcutils: ashmem print error message for invalid fd
NB: We decided to not sniff for the constant saved __ashmem_rdev in
the early error path; requiring either the use of atomic operations,
or acquiring a lock to do it correctly. The heroics are not worth it.
Bug: 26871259
Change-Id: I46249838850ae32063eb5b7d08c731c5bb0fbf6b
Diffstat (limited to 'libcutils/ashmem-dev.c')
-rw-r--r-- | libcutils/ashmem-dev.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/libcutils/ashmem-dev.c b/libcutils/ashmem-dev.c index 77e4d0d97..d6a48c953 100644 --- a/libcutils/ashmem-dev.c +++ b/libcutils/ashmem-dev.c @@ -19,6 +19,7 @@ * ashmem-enabled kernel. See ashmem-sim.c for the "fake" tmp-based version, * used by the simulator. */ +#define LOG_TAG "ashmem" #include <errno.h> #include <fcntl.h> @@ -32,6 +33,7 @@ #include <linux/ashmem.h> #include <cutils/ashmem.h> +#include <log/log.h> #define ASHMEM_DEVICE "/dev/ashmem" @@ -92,6 +94,7 @@ static int __ashmem_is_ashmem(int fd) return -1; } + rdev = 0; /* Too much complexity to sniff __ashmem_rdev */ if (S_ISCHR(st.st_mode) && st.st_rdev) { pthread_mutex_lock(&__ashmem_lock); rdev = __ashmem_rdev; @@ -114,6 +117,17 @@ static int __ashmem_is_ashmem(int fd) } } + if (rdev) { + ALOGE("illegal fd=%d mode=0%o rdev=%d:%d expected 0%o %d:%d", + fd, st.st_mode, major(st.st_rdev), minor(st.st_rdev), + S_IFCHR | S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IRGRP, + major(rdev), minor(rdev)); + } else { + ALOGE("illegal fd=%d mode=0%o rdev=%d:%d expected 0%o", + fd, st.st_mode, major(st.st_rdev), minor(st.st_rdev), + S_IFCHR | S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IRGRP); + } + errno = ENOTTY; return -1; } |