/*- * Copyright (c) 2002-2018 The UbixOS Project. * All rights reserved. * * This was developed by Christopher W. Olsen for the UbixOS Project. * * Redistribution and use in source and binary forms, with or without modification, are permitted * provided that the following conditions are met: * * 1) Redistributions of source code must retain the above copyright notice, this list of * conditions, the following disclaimer and the list of authors. * 2) Redistributions in binary form must reproduce the above copyright notice, this list of * conditions, the following disclaimer and the list of authors in the documentation and/or * other materials provided with the distribution. * 3) Neither the name of the UbixOS Project nor the names of its contributors may be used to * endorse or promote products derived from this software without specific prior written * permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include <sys/kern_descrip.h> #include <sys/sysproto.h> #include <sys/thread.h> #include <lib/kprintf.h> #include <ubixos/endtask.h> #include <lib/kmalloc.h> #include <assert.h> int fcntl(struct thread *td, struct fcntl_args *uap) { struct file *fp = 0x0; #ifdef DEBUG kprintf("[%s:%i]",__FILE__,__LINE__); #endif if (td->o_files[uap->fd] == 0x0) { kprintf("ERROR!!!\n"); return (-1); } fp = (struct file *) td->o_files[uap->fd]; switch (uap->cmd) { case 3: td->td_retval[0] = fp->f_flag; break; case 4: fp->f_flag &= ~FCNTLFLAGS; fp->f_flag |= FFLAGS(uap->arg & ~O_ACCMODE) & FCNTLFLAGS; break; default: kprintf("ERROR DEFAULT"); } return (0x0); } int falloc(struct thread *td, struct file **resultfp, int *resultfd) { struct file *fp = 0x0; int i = 0; #ifdef DEBUG kprintf("[%s:%i]",__FILE__,__LINE__); #endif fp = (struct file *) kmalloc(sizeof(struct file)); /* First 5 Descriptors Are Reserved */ for (i = 5; i < 1024; i++) { if (td->o_files[i] == 0x0) { td->o_files[i] = (void *) fp; if (resultfd) *resultfd = i; if (resultfp) *resultfp = fp; break; } } return (0x0); } int close(struct thread *td, struct close_args *uap) { #ifdef DEBUG kprintf("[%s:%i]",__FILE__,__LINE__); #endif kfree((void *) td->o_files[uap->fd]); td->o_files[uap->fd] = 0x0; td->td_retval[0] = 0x0; return (0x0); } /*! * \brief return data table size */ int getdtablesize(struct thread *td, struct getdtablesize_args *uap) { #ifdef DEBUG kprintf("[%s:%i]",__FILE__,__LINE__); #endif td->td_retval[0] = O_FILES; return (0); } /* HACK */ int fstat(struct thread *td, struct fstat_args *uap) { struct file *fp = 0x0; #ifdef DEBUG kprintf("[%s:%i]",__FILE__,__LINE__); #endif fp = (struct file *) _current->td.o_files[uap->fd]; uap->sb->st_mode = 0x2180; uap->sb->st_blksize = 0x1000; kprintf("fstat: %i", uap->fd); return (0x0); } /*! * \brief ioctl functionality not implimented yet * * \returns NULL for now */ int ioctl(struct thread *td, struct ioctl_args *uap) { td->td_retval[0] = 0x0; return (0x0); } /*! * \brief get pointer to file fd in specified thread * * \return returns fp */ int getfd(struct thread *td, struct file **fp, int fd) { int error = 0x0; #ifdef DEBUG kprintf("[%s:%i]",__FILE__,__LINE__); #endif *fp = (struct file *) td->o_files[fd]; if (fp == 0x0) error = -1; return (error); } /*** END ***/