/* * l4/posix glue for open() * * Copyright (C) 2007 Bahadir Balban */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include INC_GLUE(memory.h) /* * Arguments that are too large to fit in message registers are * copied onto another area that is still on the utcb, and the servers * map-in the task utcb and read those arguments from there. */ void *copy_to_utcb(void *arg, int size) { BUG_ON(size > PAGE_SIZE); memcpy(utcb_page, arg, size); } static inline int l4_open(const char *pathname, int flags, mode_t mode) { int fd; // write_mr(L4SYS_ARG0, (unsigned long)pathname); copy_to_utcb((void *)pathname, strlen(pathname)); write_mr(L4SYS_ARG1, flags); write_mr(L4SYS_ARG2, (u32)mode); /* Call pager with shmget() request. Check ipc error. */ if ((fd = l4_sendrecv(VFS_TID, VFS_TID, L4_IPC_TAG_OPEN)) < 0) { printf("%s: L4 IPC Error: %d.\n", __FUNCTION__, fd); return fd; } /* Check if syscall itself was successful */ if ((fd = l4_get_retval()) < 0) { printf("%s: OPEN Error: %d.\n", __FUNCTION__, fd); return fd; } return fd; } int open(const char *pathname, int oflag, ...) { int ret; mode_t mode = 0; if (oflag & O_CREAT) { va_list arg; va_start(arg, oflag); mode = va_arg(arg, mode_t); va_end(arg); } ret = l4_open(pathname, oflag, mode); /* If error, return positive error code */ if (ret < 0) { errno = -ret; return -1; } /* else return value */ return ret; }