2020-02-06 00:43:02 +08:00
|
|
|
/*
|
2022-03-02 14:59:39 +08:00
|
|
|
* Copyright (C) 2020-2022 Intel Corporation
|
2020-02-06 00:43:02 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/os_interface/linux/sys_calls.h"
|
2020-02-06 00:43:02 +08:00
|
|
|
|
2021-02-23 21:03:54 +08:00
|
|
|
#include <dlfcn.h>
|
2020-02-07 21:32:02 +08:00
|
|
|
#include <fcntl.h>
|
2021-02-18 05:17:01 +08:00
|
|
|
#include <iostream>
|
2021-04-02 22:19:00 +08:00
|
|
|
#include <poll.h>
|
2021-02-18 05:17:01 +08:00
|
|
|
#include <stdio.h>
|
2020-02-13 20:26:40 +08:00
|
|
|
#include <sys/ioctl.h>
|
2021-02-18 05:17:01 +08:00
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <sys/sysmacros.h>
|
2020-02-06 00:43:02 +08:00
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
namespace NEO {
|
2021-07-09 01:19:43 +08:00
|
|
|
|
2020-02-06 00:43:02 +08:00
|
|
|
namespace SysCalls {
|
2021-07-09 01:19:43 +08:00
|
|
|
|
|
|
|
unsigned int getProcessId() {
|
|
|
|
return getpid();
|
|
|
|
}
|
|
|
|
|
2020-02-06 00:43:02 +08:00
|
|
|
int close(int fileDescriptor) {
|
|
|
|
return ::close(fileDescriptor);
|
|
|
|
}
|
2020-02-07 21:32:02 +08:00
|
|
|
int open(const char *file, int flags) {
|
|
|
|
return ::open(file, flags);
|
|
|
|
}
|
2020-02-13 20:26:40 +08:00
|
|
|
int ioctl(int fileDescriptor, unsigned long int request, void *arg) {
|
|
|
|
return ::ioctl(fileDescriptor, request, arg);
|
|
|
|
}
|
2021-02-18 05:17:01 +08:00
|
|
|
|
2021-02-23 21:03:54 +08:00
|
|
|
void *dlopen(const char *filename, int flag) {
|
|
|
|
return ::dlopen(filename, flag);
|
|
|
|
}
|
|
|
|
|
2021-02-18 05:17:01 +08:00
|
|
|
int access(const char *pathName, int mode) {
|
|
|
|
return ::access(pathName, mode);
|
|
|
|
}
|
|
|
|
|
|
|
|
int readlink(const char *path, char *buf, size_t bufsize) {
|
|
|
|
return static_cast<int>(::readlink(path, buf, bufsize));
|
|
|
|
}
|
|
|
|
|
|
|
|
int getDevicePath(int deviceFd, char *buf, size_t &bufSize) {
|
|
|
|
struct stat st;
|
2021-03-29 20:01:37 +08:00
|
|
|
if (::fstat(deviceFd, &st)) {
|
2021-02-18 05:17:01 +08:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
snprintf(buf, bufSize, "/sys/dev/char/%d:%d",
|
|
|
|
major(st.st_rdev), minor(st.st_rdev));
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2021-04-02 22:19:00 +08:00
|
|
|
|
|
|
|
int poll(struct pollfd *pollFd, unsigned long int numberOfFds, int timeout) {
|
|
|
|
return ::poll(pollFd, numberOfFds, timeout);
|
|
|
|
}
|
2021-03-29 20:01:37 +08:00
|
|
|
|
|
|
|
int fstat(int fd, struct stat *buf) {
|
|
|
|
return ::fstat(fd, buf);
|
|
|
|
}
|
2021-05-28 00:41:47 +08:00
|
|
|
|
|
|
|
ssize_t pread(int fd, void *buf, size_t count, off_t offset) {
|
|
|
|
return ::pread(fd, buf, count, offset);
|
|
|
|
}
|
|
|
|
|
2021-08-27 01:35:15 +08:00
|
|
|
ssize_t pwrite(int fd, const void *buf, size_t count, off_t offset) {
|
|
|
|
return ::pwrite(fd, buf, count, offset);
|
|
|
|
}
|
|
|
|
|
2021-06-18 02:25:55 +08:00
|
|
|
void *mmap(void *addr, size_t size, int prot, int flags, int fd, off_t off) {
|
|
|
|
return ::mmap(addr, size, prot, flags, fd, off);
|
|
|
|
}
|
|
|
|
|
|
|
|
int munmap(void *addr, size_t size) {
|
|
|
|
return ::munmap(addr, size);
|
|
|
|
}
|
2022-03-02 14:59:39 +08:00
|
|
|
|
|
|
|
ssize_t read(int fd, void *buf, size_t count) {
|
|
|
|
return ::read(fd, buf, count);
|
|
|
|
}
|
|
|
|
|
2020-02-06 00:43:02 +08:00
|
|
|
} // namespace SysCalls
|
|
|
|
} // namespace NEO
|