aboutsummaryrefslogtreecommitdiff
path: root/sys/i386/linux/linux_file.c
Commit message (Collapse)AuthorAgeFilesLines
* Finish the Linuxulator MD/MI split.Marcel Moolenaar2000-08-221-879/+0
| | | | | | | | | | | | In summary: o This file has been moved to sys/compat/linux, o Any MD syscalls in this file are moved to linux_machdep.c in sys/i386/linux, o Include directives, makefiles and config files have been updated. Notes: svn path=/head/; revision=64931
* Implement pread and pwrite.Marcel Moolenaar2000-07-171-0/+28
| | | | | | | | PR: 17991 Submitted by: Geoffrey Speicher <geoff@caribbean.sea-incorporated.com> Notes: svn path=/head/; revision=63285
* Simplify the F_GETOWN and F_SETOWN fcntl commands. The workaroundMarcel Moolenaar2000-07-151-49/+7
| | | | | | | | | | | is not needed since the FreeBSD native implementation switched from TIOC{G|S}PGRP to FIO{G|S}ETOWN (kern_descrip.c rev 1.55). PR: 16946 Submitted by: Victor Salaman <salaman@teknos.com> Notes: svn path=/head/; revision=63233
* Implement fdatasync in terms of fsync. The regeneration of proto.h,Marcel Moolenaar1999-11-261-0/+11
| | | | | | | | syscall.h and sysent.h was probably forgotten after the last change syscalls.master. Notes: svn path=/head/; revision=53713
* simplify check for device.Poul-Henning Kamp1999-11-081-1/+1
| | | | Notes: svn path=/head/; revision=53009
* Fix the duplicate filenames that are the result of using getdents.Marcel Moolenaar1999-10-211-1/+1
| | | | | | | | | | | | | | glibc2 defines struct dirent differently than the Linux kernel does. The getdents function therefore needs to read a heuristically defined number of kernel dirents to satisfy the request. In case where too many kernel dirents have been read, the function lseeks on the directory so that a next call will start with the right dirent. The offset used in lseeking is the offset-field in the last dirent passed to the application. This can only mean that the offset-field holds the offset of the next dirent and not the offset of the dirent itself. Notes: svn path=/head/; revision=52421
* This patch clears the way for removing a number of tty relatedPoul-Henning Kamp1999-09-251-4/+5
| | | | | | | | | | | | | | | | | | | | | | | | fields in struct cdevsw: d_stop moved to struct tty. d_reset already unused. d_devtotty linkage now provided by dev_t->si_tty. These fields will be removed from struct cdevsw together with d_params and d_maxio Real Soon Now. The changes in this patch consist of: initialize dev->si_tty in *_open() initialize tty->t_stop remove devtotty functions rename ttpoll to ttypoll a few adjustments to these changes in the generic code a bump of __FreeBSD_version add a couple of FreeBSD tags Notes: svn path=/head/; revision=51654
* This is what was "fdfix2.patch," a fix for fd sharing. It's prettyBrian Feldman1999-09-191-1/+1
| | | | | | | | | | | | | | | | | | | | far-reaching in fd-land, so you'll want to consult the code for changes. The biggest change is that now, you don't use fp->f_ops->fo_foo(fp, bar) but instead fo_foo(fp, bar), which increments and decrements the fp refcount upon entry and exit. Two new calls, fhold() and fdrop(), are provided. Each does what it seems like it should, and if fdrop() brings the refcount to zero, the fd is freed as well. Thanks to peter ("to hell with it, it looks ok to me.") for his review. Thanks to msmith for keeping me from putting locks everywhere :) Reviewed by: peter Notes: svn path=/head/; revision=51418
* Fix getcwd. It must return the length of the path including the terminating 0.Marcel Moolenaar1999-09-171-6/+19
| | | | | | | | | While I'm here, fix style and debug printf. Fix derived from patch by: Darryl Okahata <darrylo@sr.hp.com> Notes: svn path=/head/; revision=51348
* $Id$ -> $FreeBSD$Peter Wemm1999-08-281-1/+1
| | | | Notes: svn path=/head/; revision=50477
* Fix bug in the fcntl syscall where 'arg' was not set properly.Marcel Moolenaar1999-08-151-2/+4
| | | | | | | | PR: 12147 Submitted by: Allan Saddi <asaddi@philosophysw.com> Notes: svn path=/head/; revision=49845
* Implementation of the linux_getcwd syscall.Marcel Moolenaar1999-08-141-1/+16
| | | | Notes: svn path=/head/; revision=49788
* In doing lock type conversion (struct flock), make sure that carbage in resultsMarcel Moolenaar1999-08-131-2/+5
| | | | | | | | | | | in deterministic behaviour. In this case known garbage out. The fix is different than suggested in the PR. PR: 12749 Originator: Boris Nikolaus <boris@cs.tu-berlin.de> Notes: svn path=/head/; revision=49676
* Use a wrapper for the link syscall that does name translations.Marcel Moolenaar1999-08-121-1/+20
| | | | | | | | PR: 12749 Submitted by: Boris Nikolaus <boris@cs.tu-berlin.de> Notes: svn path=/head/; revision=49662
* Use the vn_todev() function, rather than VOP_GETATTRPoul-Henning Kamp1999-07-181-7/+3
| | | | Notes: svn path=/head/; revision=48885
* Divorce "dev_t" from the "major|minor" bitmap, which is now calledPoul-Henning Kamp1999-05-111-3/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | udev_t in the kernel but still called dev_t in userland. Provide functions to manipulate both types: major() umajor() minor() uminor() makedev() umakedev() dev2udev() udev2dev() For now they're functions, they will become in-line functions after one of the next two steps in this process. Return major/minor/makedev to macro-hood for userland. Register a name in cdevsw[] for the "filedescriptor" driver. In the kernel the udev_t appears in places where we have the major/minor number combination, (ie: a potential device: we may not have the driver nor the device), like in inodes, vattr, cdevsw registration and so on, whereas the dev_t appears where we carry around a reference to a actual device. In the future the cdevsw and the aliased-from vnode will be hung directly from the dev_t, along with up to two softc pointers for the device driver and a few houskeeping bits. This will essentially replace the current "alias" check code (same buck, bigger bang). A little stunt has been provided to try to catch places where the wrong type is being used (dev_t vs udev_t), if you see something not working, #undef DEVT_FASCIST in kern/kern_conf.c and see if it makes a difference. If it does, please try to track it down (many hands make light work) or at least try to reproduce it as simply as possible, and describe how to do that. Without DEVT_FASCIST I belive this patch is a no-op. Stylistic/posixoid comments about the userland view of the <sys/*.h> files welcome now, from userland they now contain the end result. Next planned step: make all dev_t's refer to the same devsw[] which means convert BLK's to CHR's at the perimeter of the vnodes and other places where they enter the game (bootdev, mknod, sysctl). Notes: svn path=/head/; revision=47028
* I got tired of seeing all the cdevsw[major(foo)] all over the place.Poul-Henning Kamp1999-05-081-2/+2
| | | | | | | | | | | Made a new (inline) function devsw(dev_t dev) and substituted it. Changed to the BDEV variant to this format as well: bdevsw(dev_t dev) DEVFS will eventually benefit from this change too. Notes: svn path=/head/; revision=46676
* Fix up a few easy 'assignment used as truth value' and 'suggest parensPeter Wemm1999-05-061-2/+3
| | | | | | | | around && within ||' type warnings. I'm pretty sure I have not masked any problems here, I've committed real problem fixes seperately. Notes: svn path=/head/; revision=46571
* Use truncate() instead of otruncate() - step on the way to stoppingEivind Eklund1999-01-101-3/+3
| | | | | | | the linulator from depending on COMPAT_43. Notes: svn path=/head/; revision=42499
* Make async I/O on a socket work.John Fieber1998-10-051-1/+4
| | | | | | | | Although the current Sybase license does not permit running under emulation, FreeBSD 3.0 is now "Sybase Ready" should the license change. Notes: svn path=/head/; revision=39978
* Fixed print format errors.Bruce Evans1998-07-291-5/+5
| | | | Notes: svn path=/head/; revision=37950
* The linux chown syscall is more like lchown, a new chown syscall thatPeter Wemm1998-03-291-1/+22
| | | | | | | follows links was added. Notes: svn path=/head/; revision=34941
* sigh....forgot to update the DEBUG printfJonathan M. Bresler1998-01-051-3/+3
| | | | | | | | | | to show both the path and the length args to linux emulation truncate() Submitted by: jmb Notes: svn path=/head/; revision=32266
* length argument to truncate() in linux emulationJonathan M. Bresler1998-01-051-1/+2
| | | | | | | | | | | | was not being set copied to the bsd arguments.. frequently, resulting in files of over 100MB of NULs PR: 386/5044 Reviewed by: jmb Submitted by: (Richard Winkel) rich@math.missouri.edu Notes: svn path=/head/; revision=32265
* Make hidden COMPAT_43 dependencies explict. Options in headers is aEivind Eklund1997-12-161-1/+3
| | | | | | | pain in the backside. Notes: svn path=/head/; revision=31784
* Don't include <sys/lock.h> in headers when only `struct simplelock' isBruce Evans1997-12-051-1/+2
| | | | | | | required. Fixed everything that depended on the pollution. Notes: svn path=/head/; revision=31561
* Move the "retval" (3rd) parameter from all syscall functions and putPoul-Henning Kamp1997-11-061-58/+59
| | | | | | | | | | | | | | | it in struct proc instead. This fixes a boatload of compiler warning, and removes a lot of cruft from the sources. I have not removed the /*ARGSUSED*/, they will require some looking at. libkvm, ps and other userland struct proc frobbing programs will need recompiled. Notes: svn path=/head/; revision=30994
* Remove dependancy on UFS' DIRBLKSIZ definition.Doug Rabson1997-04-061-6/+2
| | | | | | | | | 2.2 candidate. Submitted by: bde Notes: svn path=/head/; revision=24672
* Fix linux_getdents so that it can cope with filesystems which translateDoug Rabson1997-04-051-10/+46
| | | | | | | | | | | the directory format (ext2fs, cd9660). For these filesystems, it must use cookies to find the correct offset to use for subsequent reads. Without it, linux /bin/ls tends to loop re-reading the same block over and over again. 2.2 candidate. Notes: svn path=/head/; revision=24654
* Don't include <sys/ioctl.h> in the kernel. Stage 1: don't includeBruce Evans1997-03-241-2/+1
| | | | | | | | it when it is not used. In most cases, the reasons for including it went away when the special ioctl headers became self-sufficient. Notes: svn path=/head/; revision=24203
* Back out part 1 of the MCFH that changed $Id$ to $FreeBSD$. We are notPeter Wemm1997-02-221-1/+1
| | | | | | | ready for it yet. Notes: svn path=/head/; revision=22975
* Make this compile again after the Lite2 merge.Mike Pritchard1997-02-101-3/+2
| | | | | | | | | VOP_UNLOCK was being called with the wrong mumber of arguments. Also silenced a -Wall warning. Notes: svn path=/head/; revision=22543
* This is the kernel Lite/2 commit. There are some requisite userlandJohn Dyson1997-02-101-2/+2
| | | | | | | | | | | | | | | | | | changes, so don't expect to be able to run the kernel as-is (very well) without the appropriate Lite/2 userland changes. The system boots and can mount UFS filesystems. Untested: ext2fs, msdosfs, NFS Known problems: Incorrect Berkeley ID strings in some files. Mount_std mounts will not work until the getfsent library routine is changed. Reviewed by: various people Submitted by: Jeffery Hsu <hsu@freebsd.org> Notes: svn path=/head/; revision=22521
* Make the long-awaited change from $Id$ to $FreeBSD$Jordan K. Hubbard1997-01-141-1/+1
| | | | | | | | | | | This will make a number of things easier in the future, as well as (finally!) avoiding the Id-smashing problem which has plagued developers for so long. Boy, I'm glad we're not using sup anymore. This update would have been insane otherwise. Notes: svn path=/head/; revision=21673
* Fix the getdents() emulation, the Linux ELF libraries use this, andPeter Wemm1996-03-101-3/+11
| | | | | | | | | | this code was not quite right (linux has a readdir and getdents syscall, with the same args. readdir only returns one entry and uses a mutant dirent structure. This code was also returning the mutant form for getdents as well. My fault for missing this before.) Notes: svn path=/head/; revision=14465
* Mega-commit for Linux emulator update.. This has been stress tested underPeter Wemm1996-03-021-43/+354
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | netscape-2.0 for Linux running all the Java stuff. The scrollbars are now working, at least on my machine. (whew! :-) I'm uncomfortable with the size of this commit, but it's too inter-dependant to easily seperate out. The main changes: COMPAT_LINUX is *GONE*. Most of the code has been moved out of the i386 machine dependent section into the linux emulator itself. The int 0x80 syscall code was almost identical to the lcall 7,0 code and a minor tweak allows them to both be used with the same C code. All kernels can now just modload the lkm and it'll DTRT without having to rebuild the kernel first. Like IBCS2, you can statically compile it in with "options LINUX". A pile of new syscalls implemented, including getdents(), llseek(), readv(), writev(), msync(), personality(). The Linux-ELF libraries want to use some of these. linux_select() now obeys Linux semantics, ie: returns the time remaining of the timeout value rather than leaving it the original value. Quite a few bugs removed, including incorrect arguments being used in syscalls.. eg: mixups between passing the sigset as an int, vs passing it as a pointer and doing a copyin(), missing return values, unhandled cases, SIOC* ioctls, etc. The build for the code has changed. i386/conf/files now knows how to build linux_genassym and generate linux_assym.h on the fly. Supporting changes elsewhere in the kernel: The user-mode signal trampoline has moved from the U area to immediately below the top of the stack (below PS_STRINGS). This allows the different binary emulations to have their own signal trampoline code (which gets rid of the hardwired syscall 103 (sigreturn on BSD, syslog on Linux)) and so that the emulator can provide the exact "struct sigcontext *" argument to the program's signal handlers. The sigstack's "ss_flags" now uses SS_DISABLE and SS_ONSTACK flags, which have the same values as the re-used SA_DISABLE and SA_ONSTACK which are intended for sigaction only. This enables the support of a SA_RESETHAND flag to sigaction to implement the gross SYSV and Linux SA_ONESHOT signal semantics where the signal handler is reset when it's triggered. makesyscalls.sh no longer appends the struct sysentvec on the end of the generated init_sysent.c code. It's a lot saner to have it in a seperate file rather than trying to update the structure inside the awk script. :-) At exec time, the dozen bytes or so of signal trampoline code are copied to the top of the user's stack, rather than obtaining the trampoline code the old way by getting a clone of the parent's user area. This allows Linux and native binaries to freely exec each other without getting trampolines mixed up. Notes: svn path=/head/; revision=14331
* Clean up some warnings by using the generated structures in <sys/sysproto.h>Peter Wemm1995-12-151-16/+14
| | | | | | | | for passing to the bsd system calls, rather than inveninting our own equivalent structures. Notes: svn path=/head/; revision=12858
* Completed function declarations and added prototypes.Bruce Evans1995-11-221-4/+7
| | | | | | | | | Removed some unnecessary #includes. Fixed warnings about nested externs. Notes: svn path=/head/; revision=12458
* Fix the getdirentries of ibcs2 to handle uneven DIRBLKSIZ offsets.Steven Wallace1995-10-101-6/+8
| | | | | | | | | | Slight modification from previous fix. Also, fix problem where an entry would be skipped next call if not enough room in buffer current call. Notes: svn path=/head/; revision=11418
* Modified linux_readdir() function to properly handle Linux readdir()Steven Wallace1995-08-281-14/+27
| | | | | | | | | calls with a byte size of 1. This special case was not correctly emulated. Now programs such as a simple 'ls' to a commercial Macintosh emulator called 'executor' will work correctly. Notes: svn path=/head/; revision=10355
* First incarnation of our Linux emulator or rather compatibility code.Søren Schmidt1995-06-251-0/+436
This first shot only incorporaties so much functionality that DOOM can run (the X version), signal handling is VERY weak, so is many other things. But it meets my milestone number one (you guessed it - running DOOM). Uses /compat/linux as prefix for loading shared libs, so it won't conflict with our own libs. Kernel must be compiled with "options COMPAT_LINUX" for this to work. Notes: svn path=/head/; revision=9313