History log of /src/sys/compat/linux/common/linux_file64.c |
Revision | | Date | Author | Comments |
1.68 |
| 29-Jul-2023 |
christos | Add/fix statx, readahead, close_range. From GSoC 2023 by Theodore Preduta
|
1.67 |
| 25-Nov-2021 |
ryo | - Add compat_linux statx(2) syscall. - The AT_EMPTY_PATH processing from the modification of sys/compat/linux/common/linux_file64.c r1.63 has been separated, and made common to linux_statat(), so that it can be used not only by linux32_sys_fstatat64() but also by other *statat() variants.
|
1.66 |
| 25-Nov-2021 |
ryo | rename bsd_to_linux_stat() to bsd_to_linux_stat64() to avoid confusion. There is a static function with the same name in linux/common/linux_file.c.
NFC.
|
1.65 |
| 25-Nov-2021 |
ryo | rename bsd_to_linux_stat() to bsd_to_linux_stat64() to avoid confusion. There is a static function with the same name in linux/common/linux_file.c.
NFC.
|
1.64 |
| 23-Sep-2021 |
ryo | add support COMPAT_LINUX for aarch64
|
1.63 |
| 21-Sep-2021 |
rin | linux_sys_fstatat64: Add support for AT_EMPTY_PATH flag.
This is required for rtld shipped with glibc 2.33.
Now, userland of Fedora 34 is working fine on NetBSD/amd64.
|
1.62 |
| 23-Aug-2019 |
maxv | Fix info leaks.
|
1.61 |
| 23-Aug-2019 |
maxv | Fix info leak.
|
1.60 |
| 03-Sep-2018 |
riastradh | branches: 1.60.4; Rename min/max -> uimin/uimax for better honesty.
These functions are defined on unsigned int. The generic name min/max should not silently truncate to 32 bits on 64-bit systems. This is purely a name change -- no functional change intended.
HOWEVER! Some subsystems have
#define min(a, b) ((a) < (b) ? (a) : (b)) #define max(a, b) ((a) > (b) ? (a) : (b))
even though our standard name for that is MIN/MAX. Although these may invite multiple evaluation bugs, these do _not_ cause integer truncation.
To avoid `fixing' these cases, I first changed the name in libkern, and then compile-tested every file where min/max occurred in order to confirm that it failed -- and thus confirm that nothing shadowed min/max -- before changing it.
I have left a handful of bootloaders that are too annoying to compile-test, and some dead code:
cobalt ews4800mips hp300 hppa ia64 luna68k vax acorn32/if_ie.c (not included in any kernels) macppc/if_gm.c (superseded by gem(4))
It should be easy to fix the fallout once identified -- this way of doing things fails safe, and the goal here, after all, is to _avoid_ silent integer truncations, not introduce them.
Maybe one day we can reintroduce min/max as type-generic things that never silently truncate. But we should avoid doing that for a while, so that existing code has a chance to be detected by the compiler for conversion to uimin/uimax without changing the semantics until we can properly audit it all. (Who knows, maybe in some cases integer truncation is actually intended!)
|
1.59 |
| 28-Jul-2017 |
riastradh | branches: 1.59.2; 1.59.4; Fail, don't panic, on bad dirents from file system.
Controllable via puffs from userland.
From Ilja Van Sprundel.
|
1.58 |
| 28-Jan-2017 |
christos | branches: 1.58.6; copy the terminating NUL (njoly)
|
1.57 |
| 13-Jan-2017 |
christos | branches: 1.57.2; fix typo
|
1.56 |
| 13-Jan-2017 |
christos | convert strcpy to a bounded copy to avoid compiler warnings, although the reclen test prevents overflow.
|
1.55 |
| 27-Dec-2013 |
njoly | branches: 1.55.4; 1.55.6; 1.55.8; 1.55.10; 1.55.14; Add struct linux_stat64 definition for alpha, and enable syscalls that use it.
|
1.54 |
| 18-Nov-2013 |
chs | implement the *at() syscalls. bring the unimplemented syscall list up to date.
|
1.53 |
| 14-Oct-2011 |
hannken | branches: 1.53.2; 1.53.8; 1.53.12; 1.53.14; 1.53.16; 1.53.22; Change the vnode locking protocol of VOP_GETATTR() to request at least a shared lock. Make all calls outside of file systems respect it.
The calls from file systems need review.
No objections from tech-kern.
|
1.52 |
| 01-Sep-2011 |
njoly | Make linux_sys_getdents64 fails with ENOTDIR instead of EINVAL, when fd does not refer to a directory.
|
1.51 |
| 24-Jun-2010 |
hannken | Clean up vnode lock operations pass 2:
VOP_UNLOCK(vp, flags) -> VOP_UNLOCK(vp): Remove the unneeded flags argument.
Welcome to 5.99.32.
Discussed on tech-kern.
|
1.50 |
| 03-Mar-2010 |
he | branches: 1.50.2; When implementing "read directory", when there are too many empty entries in a row, and we need to try to read the next block, and have passed a non-NULL cookie pointer to VOP_READDIR, ensure that we free the cookie buffer before re-doing VOP_READDIR, so that we don't leak memory. This fix is similar to nfs_serv.c revisions 1.115 + 1.124.
This should fix the long-standing problem observed by e.g. using Linux- emulated programs to take backup of servers, which is one of the problems which were reported in PR#42661.
Thanks to pooka@ for the hints for traversing the VOP* layer.
|
1.49 |
| 15-May-2009 |
pooka | branches: 1.49.2; pad -> PAD
|
1.48 |
| 24-Jun-2008 |
ad | branches: 1.48.6; 1.48.10; 1.48.14; Replace references to getsock/getvnode.
|
1.47 |
| 28-Apr-2008 |
martin | branches: 1.47.2; 1.47.4; Remove clause 3 and 4 from TNF licenses
|
1.46 |
| 21-Mar-2008 |
ad | branches: 1.46.2; 1.46.4; Catch up with descriptor handling changes. See kern_descrip.c revision 1.173 for details.
|
1.45 |
| 02-Feb-2008 |
dsl | branches: 1.45.6; Extract the fcntl64() suppoort from linux_file64.c into linux_fcntl64.c Unravel some of the knots that caused linux_file64.c to be compiled twice for an amd64 kernel (once for linux and once for linux32) with different parts being skipped each time.
|
1.44 |
| 20-Dec-2007 |
dsl | Convert all the system call entry points from: int foo(struct lwp *l, void *v, register_t *retval) to: int foo(struct lwp *l, const struct foo_args *uap, register_t *retval) Fixup compat code to not write into 'uap' and (in some cases) to actually pass a correctly formatted 'uap' structure with the right name to the next routine. A few 'compat' routines that just call standard ones have been deleted. All the 'compat' code compiles (along with the kernels required to test build it). 98% done by automated scripts.
|
1.43 |
| 08-Dec-2007 |
dsl | branches: 1.43.4; ANSIfy most of the function definitions in sys/compat (but not ndis). All by the magic of sed ...
|
1.42 |
| 04-Dec-2007 |
dsl | Remove all the __P
|
1.41 |
| 26-Nov-2007 |
pooka | branches: 1.41.2; Remove the "struct lwp *" argument from all VFS and VOP interfaces. The general trend is to remove it from all kernel interfaces and this is a start. In case the calling lwp is desired, curlwp should be used.
quick consensus on tech-kern
|
1.40 |
| 19-Oct-2007 |
njoly | branches: 1.40.2; Add compat_linux and exec_linux_elf lkm support for amd64: - Add needed COMPAT_OSSAUDIO to GENERIC. - Add missing includes needed by linux_syscallargs.h. - Add lkm building.
|
1.39 |
| 12-May-2007 |
dsl | branches: 1.39.6; 1.39.8; 1.39.12; Split the fcntl locking code out from its copyin/out. Use to avoid all the stackgap stuff in compat code.
|
1.38 |
| 22-Apr-2007 |
dsl | Change the way that emulations locate files within the emulation root to avoid having to allocate space in the 'stackgap' - which is very LWP unfriendly. The additional code for non-emulation namei() is trivial, the reduction for the emulations is massive. The vnode for a processes emulation root is saved in the cwdi structure during process exec. If the emulation root the TRYEMULROOT flag are set, namei() will do an initial search for absolute pathnames in the emulation root, if that fails it will retry from the normal root. ".." at the emulation root will always go to the real root, even in the middle of paths and when expanding symlinks. Absolute symlinks found using absolute paths in the emulation root will be relative to the emulation root (so /usr/lib/xxx.so -> /lib/xxx.so links inside the emulation root don't need changing). If the root of the emulation would be returned (for an emulation lookup), then the real root is returned instead (matching the behaviour of emul_lookup, but being a cheap comparison here) so that programs that scan "../.." looking for the root dircetory don't loop forever. The target for symbolic links is no longer mangled (it used to get the CHECK_ALT_xxx() treatment, so could get /emul/xxx prepended). CHECK_ALT_xxx() are no more. Most of the change is deleting them, and adding TRYEMULROOT to the flags to NDINIT(). A lot of the emulation system call stubs could now be deleted.
|
1.37 |
| 10-Mar-2007 |
dsl | branches: 1.37.2; Update all the compat stuff to not use the 'stackgap' for processing sys_stat() and friends, instead use do_sys_stat() and do_sys_fstat() that write the answer into a kernel buffer (on stack) that can be converted to the correct form and written the userspace. I've test compiled a few kernels, and tested i386 netbsd1.6 ls. Given I think I've fixed some bugs, it might be 50-50 with new ones.
|
1.36 |
| 04-Mar-2007 |
christos | branches: 1.36.2; Kill caddr_t; there will be some MI fallout, but it will be fixed shortly.
|
1.35 |
| 09-Feb-2007 |
ad | branches: 1.35.2; Merge newlock2 to head.
|
1.34 |
| 23-Jul-2006 |
ad | branches: 1.34.4; 1.34.8; Use the LWP cached credentials where sane.
|
1.33 |
| 14-May-2006 |
elad | integrate kauth.
|
1.32 |
| 01-Mar-2006 |
yamt | branches: 1.32.2; 1.32.4; 1.32.6; merge yamt-uio_vmspace branch.
- use vmspace rather than proc or lwp where appropriate. the latter is more natural to specify an address space. (and less likely to be abused for random purposes.) - fix a swdmover race.
|
1.31 |
| 09-Feb-2006 |
manu | Add initial (but unfinished) COMPAT_LINUX32 for amd64. This is good enough so that the i386 license manager part of amd64 version of Fluent works.
While I'm here, add SysV IPC to COMPAT_LINUX/amd64
|
1.30 |
| 11-Dec-2005 |
christos | branches: 1.30.2; 1.30.4; 1.30.6; merge ktrace-lwp.
|
1.29 |
| 19-Aug-2005 |
christos | 64 bit inode changes.
|
1.28 |
| 29-May-2005 |
christos | branches: 1.28.2; - sprinkle const. - add XXXUNCONST to the emul_find() pbuf argument free'ing. XXX: this needs an api change. - avoid variable shadowing.
|
1.27 |
| 03-May-2005 |
manu | First work on COMPAT_LINUX/amd64 Process startup and dynamiclinking work, but processes hang due to Linux arch_prctl(2) not being really supported yet.
|
1.26 |
| 19-Apr-2005 |
christos | PR/29696: Joel Carnat: NetBSD freezes when accessing smbfs mounted FS with firefox/linux due to compat getdents() call assumption that all filesystems support cookies.
|
1.25 |
| 10-Mar-2005 |
christos | branches: 1.25.2; Add nanosecond handling on the stat and stat64 code for the i386.
|
1.24 |
| 26-Feb-2005 |
perry | nuke trailing whitespace
|
1.23 |
| 17-Sep-2004 |
skrll | branches: 1.23.4; 1.23.6; There's no need to pass a proc value when using UIO_SYSSPACE with vn_rdwr(9) and uiomove(9).
OK'd by Jason Thorpe
|
1.22 |
| 10-Aug-2003 |
jdolecek | add Linux compat arg wrapper for ftruncate64(), and change linux compat truncate64() wrapper to translate args structure NetBSD truncate() and ftrucate() have hidden 'pad' argument, so we have to do the argument translation
Problem found and patch supplied in PR kern/22360 by Ales Krenek
This is the last of syscalls with hidden 'pad' arg we didn't have wrapper for; all the others (lseek, mmap, pwrite, pread) already had wrapper before.
|
1.21 |
| 29-Jun-2003 |
fvdl | branches: 1.21.2; Back out the lwp/ktrace changes. They contained a lot of colateral damage, and need to be examined and discussed more.
|
1.20 |
| 28-Jun-2003 |
darrenr | Pass lwp pointers throughtout the kernel, as required, so that the lwpid can be inserted into ktrace records. The general change has been to replace "struct proc *" with "struct lwp *" in various function prototypes, pass the lwp through and use l_proc to get the process pointer when needed.
Bump the kernel rev up to 1.6V
|
1.19 |
| 18-Jan-2003 |
thorpej | Merge the nathanw_sa branch.
|
1.18 |
| 20-May-2002 |
jdolecek | branches: 1.18.2; linux_sys_getdents64(): remove the oldcall bug workaround cruft, it's not needed for this call, and update comment accordingly
|
1.17 |
| 20-May-2002 |
jdolecek | linux_sys_getdents64(): make the d_off member point to next entry, rather than current one; this is expected (even documented) behaviour of the new system call This fixes the endless loop when reading directories on NFS, though applications won't see all directory entries due to different problem. Fix by Matthias Scheler and Charles Hannum.
|
1.16 |
| 19-May-2002 |
jdolecek | On archs with broken linux struct stat64 st_ino, rename linux_stat64's lst_ino to __lst_ino and lst_ino64 to lst_ino, and define LINUX_STAT64_HAS_BROKEN_ST_INO. Only assign __lst_ino if this define is present.
This fixes compile on powerpc archs, and hence port-powerpc/16893.
|
1.15 |
| 13-May-2002 |
matt | branches: 1.15.2; Make COMPAT_LINUX compile again on Alpha. linux_getdents64 moved but files.linux_alpha wasn't updated. common/linux_file64.c contains a lot of syscalls which aren't on Linux/alpha so #ifdef them for alpha.
|
1.14 |
| 13-May-2002 |
simonb | Remove an unreachable "return error;".
|
1.13 |
| 12-May-2002 |
jdolecek | hook in remaining 64bit fs syscalls make most of stuff in linux_file64.c available unconditionally, with exception of fcntl64, which is not present on Linux m68k
|
1.12 |
| 10-May-2002 |
tron | Remove check for size of field "d_off" in Linux "dirent" structure because this problem cannot happen with the 64Bit version of the getdents().
|
1.11 |
| 10-May-2002 |
tron | Move implementation of linux_sys_getdents64() to source file for Linux 64bit filesystem calls.
|
1.10 |
| 22-Mar-2002 |
christos | gc debugging printfs.
|
1.9 |
| 22-Mar-2002 |
christos | implement the locking calls for linux_file64.
|
1.8 |
| 16-Mar-2002 |
christos | make the stackgap_{init,alloc} functions MP friendly (i.e. pass struct proc * in, instead of using curproc). While there add an optional size argument to stackgap_init.
|
1.7 |
| 15-Feb-2002 |
christos | - add a real linux_sys___sysctl because the mib numbers are different. implement only the kernel version getting entries. - make the signal conversion functions consistent; dest is arg 1. - make linux_fakedev deal with block and char devices differently. - add linux_sys_ugetrlimit, and flesh out the regular get/setrlimit so that they work properly. - add linux_mmap2 [untested]. - bump kernel to 2.4.18, and make the date be valentine's day :-) - linux_sys_*stat64 family was totally busted. Fix it.
tested only on i386.
Status: gdb, telnet, work jdk-1.4.0 extractor works, jdk still coredumps.
christos
|
1.6 |
| 13-Nov-2001 |
lukem | add RCSIDs (including regeneration of files as appropriate)
|
1.5 |
| 14-Oct-2001 |
manu | Fixed a minor problem so that it builds
|
1.4 |
| 30-Sep-2001 |
manu | Fixes my last commit: only mips really need fcntl64 to work now. i386 and powerpc could use it later if needed. m68k and alpha should never need it.
|
1.3 |
| 30-Sep-2001 |
manu | Added initial support for fcntl64 system call (file locking is not implemented)
|
1.2 |
| 12-Dec-2000 |
jdolecek | branches: 1.2.2; 1.2.4; 1.2.6; 1.2.8; add linux_sys_truncate64()
|
1.1 |
| 12-Dec-2000 |
jdolecek | add emulation of Linux truncate64(2), ftruncate64(2), *stat64(2)
|
1.2.8.2 |
| 11-Oct-2001 |
fvdl | Catch up with -current. Fix some bogons in the sparc64 kbd/ms attach code. cd18xx conversion provided by mrg.
|
1.2.8.1 |
| 01-Oct-2001 |
fvdl | Catch up with -current.
|
1.2.6.3 |
| 23-Jun-2002 |
jdolecek | catch up with -current on kqueue branch
|
1.2.6.2 |
| 16-Mar-2002 |
jdolecek | Catch up with -current.
|
1.2.6.1 |
| 10-Jan-2002 |
thorpej | Sync kqueue branch with -current.
|
1.2.4.10 |
| 20-Jun-2002 |
nathanw | Catch up to -current.
|
1.2.4.9 |
| 29-May-2002 |
nathanw | #include <sys/sa.h> before <sys/syscallargs.h>, to provide sa_upcall_t now that <sys/param.h> doesn't include <sys/sa.h>.
(Behold the Power of Ed)
|
1.2.4.8 |
| 01-Apr-2002 |
nathanw | Re-LWPify linux_sys_fcntl64().
|
1.2.4.7 |
| 01-Apr-2002 |
nathanw | Catch up to -current. (CVS: It's not just a program. It's an adventure!)
|
1.2.4.6 |
| 28-Feb-2002 |
nathanw | Catch up to -current.
|
1.2.4.5 |
| 06-Dec-2001 |
wdk | struct proc -> struct lwp changes for COMPAT_LINUX support on Mips processors.
|
1.2.4.4 |
| 14-Nov-2001 |
nathanw | Catch up to -current.
|
1.2.4.3 |
| 22-Oct-2001 |
nathanw | Catch up to -current.
|
1.2.4.2 |
| 08-Oct-2001 |
nathanw | Catch up to -current.
|
1.2.4.1 |
| 05-Mar-2001 |
nathanw | Initial commit of scheduler activations and lightweight process support.
|
1.2.2.2 |
| 13-Dec-2000 |
bouyer | Sync with HEAD (for UBC fixes).
|
1.2.2.1 |
| 12-Dec-2000 |
bouyer | file linux_file64.c was added on branch thorpej_scsipi on 2000-12-13 15:49:49 +0000
|
1.15.2.1 |
| 30-May-2002 |
gehenna | Catch up with -current.
|
1.18.2.2 |
| 14-Jun-2004 |
jmc | Pullup patch (requested by skrll in ticket #1708)
Bring netbsd-1-6 inline with -current sources after the mistakes in ticket #1686
|
1.18.2.1 |
| 11-May-2004 |
tron | Pull up revision 1.22 via patch (requested by wennmach in ticket #1686): add Linux compat arg wrapper for ftruncate64(), and change linux compat truncate64() wrapper to translate args structure NetBSD truncate() and ftrucate() have hidden 'pad' argument, so we have to do the argument translation Problem found and patch supplied in PR kern/22360 by Ales Krenek This is the last of syscalls with hidden 'pad' arg we didn't have wrapper for; all the others (lseek, mmap, pwrite, pread) already had wrapper before.
|
1.21.2.7 |
| 10-Nov-2005 |
skrll | Sync with HEAD. Here we go again...
|
1.21.2.6 |
| 01-Apr-2005 |
skrll | Sync with HEAD.
|
1.21.2.5 |
| 04-Mar-2005 |
skrll | Sync with HEAD.
Hi Perry!
|
1.21.2.4 |
| 21-Sep-2004 |
skrll | Fix the sync with head I botched.
|
1.21.2.3 |
| 18-Sep-2004 |
skrll | Sync with HEAD.
|
1.21.2.2 |
| 03-Aug-2004 |
skrll | Sync with HEAD
|
1.21.2.1 |
| 02-Jul-2003 |
darrenr | Apply the aborted ktrace-lwp changes to a specific branch. This is just for others to review, I'm concerned that patch fuziness may have resulted in some errant code being generated but I'll look at that later by comparing the diff from the base to the branch with the file I attempt to apply to it. This will, at the very least, put the changes in a better context for others to review them and attempt to tinker with removing passing of 'struct lwp' through the kernel.
|
1.23.6.1 |
| 19-Mar-2005 |
yamt | sync with head. xen and whitespace. xen part is not finished.
|
1.23.4.1 |
| 29-Apr-2005 |
kent | sync with -current
|
1.25.2.1 |
| 01-Oct-2005 |
tron | Pull up following revision(s) (requested by christos in ticket #838): sys/compat/svr4/svr4_misc.c: revision 1.112 sys/compat/ibcs2/ibcs2_misc.c: revision 1.74 sys/compat/linux/common/linux_misc.c: revision 1.136 sys/compat/irix/irix_dirent.c: revision 1.14 sys/compat/sunos/sunos_misc.c: revision 1.132 sys/compat/svr4_32/svr4_32_misc.c: revision 1.31 sys/compat/sunos32/sunos32_misc.c: revision 1.30 sys/compat/linux/common/linux_file64.c: revision 1.26 PR/29696: Joel Carnat: NetBSD freezes when accessing smbfs mounted FS with firefox/linux due to compat getdents() call assumption that all filesystems support cookies.
|
1.28.2.9 |
| 24-Mar-2008 |
yamt | sync with head.
|
1.28.2.8 |
| 04-Feb-2008 |
yamt | sync with head.
|
1.28.2.7 |
| 21-Jan-2008 |
yamt | sync with head
|
1.28.2.6 |
| 07-Dec-2007 |
yamt | sync with head
|
1.28.2.5 |
| 27-Oct-2007 |
yamt | sync with head.
|
1.28.2.4 |
| 03-Sep-2007 |
yamt | sync with head.
|
1.28.2.3 |
| 26-Feb-2007 |
yamt | sync with head.
|
1.28.2.2 |
| 30-Dec-2006 |
yamt | sync with head.
|
1.28.2.1 |
| 21-Jun-2006 |
yamt | sync with head.
|
1.30.6.2 |
| 01-Jun-2006 |
kardel | Sync with head.
|
1.30.6.1 |
| 22-Apr-2006 |
simonb | Sync with head.
|
1.30.4.1 |
| 09-Sep-2006 |
rpaulo | sync with head
|
1.30.2.2 |
| 18-Feb-2006 |
yamt | sync with head.
|
1.30.2.1 |
| 31-Dec-2005 |
yamt | adapt some random parts of kernel to uio_vmspace.
|
1.32.6.1 |
| 24-May-2006 |
tron | Merge 2006-05-24 NetBSD-current into the "peter-altq" branch.
|
1.32.4.1 |
| 08-Mar-2006 |
elad | Adapt to kernel authorization KPI.
|
1.32.2.3 |
| 11-Aug-2006 |
yamt | revert code which was mistakenly slipped in with 1.32.2.1.
|
1.32.2.2 |
| 11-Aug-2006 |
yamt | sync with head
|
1.32.2.1 |
| 24-May-2006 |
yamt | sync with head.
|
1.34.8.1 |
| 12-Jun-2010 |
riz | Pull up following revision(s) (requested by he in ticket #1387): sys/compat/svr4/svr4_misc.c: revision 1.149 sys/compat/linux/common/linux_misc.c: revision 1.214 sys/compat/common/vfs_syscalls_30.c: revision 1.31 sys/compat/sunos/sunos_misc.c: revision 1.166 sys/compat/linux/common/linux_file64.c: revision 1.50 sys/compat/svr4_32/svr4_32_misc.c: revision 1.68 sys/compat/ibcs2/ibcs2_misc.c: revision 1.110 sys/compat/linux32/common/linux32_dirent.c: revision 1.10 sys/compat/sunos32/sunos32_misc.c: revision 1.69 sys/compat/irix/irix_dirent.c: revision 1.24 sys/compat/osf1/osf1_file.c: revision 1.38 When implementing "read directory", when there are too many empty entries in a row, and we need to try to read the next block, and have passed a non-NULL cookie pointer to VOP_READDIR, ensure that we free the cookie buffer before re-doing VOP_READDIR, so that we don't leak memory. This fix is similar to nfs_serv.c revisions 1.115 + 1.124. This should fix the long-standing problem observed by e.g. using Linux- emulated programs to take backup of servers, which is one of the problems which were reported in PR#42661. Thanks to pooka@ for the hints for traversing the VOP* layer.
|
1.34.4.1 |
| 30-Jan-2007 |
ad | Remove support for SA. Ok core@.
|
1.35.2.3 |
| 17-May-2007 |
yamt | sync with head.
|
1.35.2.2 |
| 07-May-2007 |
yamt | sync with head.
|
1.35.2.1 |
| 12-Mar-2007 |
rmind | Sync with HEAD.
|
1.36.2.2 |
| 27-May-2007 |
ad | Sync with head.
|
1.36.2.1 |
| 13-Mar-2007 |
ad | Sync with head.
|
1.37.2.1 |
| 11-Jul-2007 |
mjf | Sync with head.
|
1.39.12.1 |
| 25-Oct-2007 |
bouyer | Sync with HEAD.
|
1.39.8.3 |
| 23-Mar-2008 |
matt | sync with HEAD
|
1.39.8.2 |
| 09-Jan-2008 |
matt | sync with HEAD
|
1.39.8.1 |
| 06-Nov-2007 |
matt | sync with HEAD
|
1.39.6.3 |
| 09-Dec-2007 |
jmcneill | Sync with HEAD.
|
1.39.6.2 |
| 27-Nov-2007 |
joerg | Sync with HEAD. amd64 Xen support needs testing.
|
1.39.6.1 |
| 26-Oct-2007 |
joerg | Sync with HEAD.
Follow the merge of pmap.c on i386 and amd64 and move pmap_init_tmp_pgtbl into arch/x86/x86/pmap.c. Modify the ACPI wakeup code to restore CR4 before jumping back into kernel space as the large page option might cover that.
|
1.40.2.3 |
| 18-Feb-2008 |
mjf | Sync with HEAD.
|
1.40.2.2 |
| 27-Dec-2007 |
mjf | Sync with HEAD.
|
1.40.2.1 |
| 08-Dec-2007 |
mjf | Sync with HEAD.
|
1.41.2.2 |
| 26-Dec-2007 |
ad | Sync with head.
|
1.41.2.1 |
| 08-Dec-2007 |
ad | Sync with head.
|
1.43.4.1 |
| 02-Jan-2008 |
bouyer | Sync with HEAD
|
1.45.6.3 |
| 29-Jun-2008 |
mjf | Sync with HEAD.
|
1.45.6.2 |
| 02-Jun-2008 |
mjf | Sync with HEAD.
|
1.45.6.1 |
| 03-Apr-2008 |
mjf | Sync with HEAD.
|
1.46.4.5 |
| 11-Aug-2010 |
yamt | sync with head.
|
1.46.4.4 |
| 11-Mar-2010 |
yamt | sync with head
|
1.46.4.3 |
| 16-May-2009 |
yamt | sync with head
|
1.46.4.2 |
| 04-May-2009 |
yamt | sync with head.
|
1.46.4.1 |
| 16-May-2008 |
yamt | sync with head.
|
1.46.2.1 |
| 18-May-2008 |
yamt | sync with head.
|
1.47.4.1 |
| 27-Jun-2008 |
simonb | Sync with head.
|
1.47.2.3 |
| 18-Sep-2008 |
wrstuden | Sync with wrstuden-revivesa-base-2.
|
1.47.2.2 |
| 14-May-2008 |
wrstuden | Per discussion with ad, remove most of the #include <sys/sa.h> lines as they were including sa.h just for the type(s) needed for syscallargs.h.
Instead, create a new file, sys/satypes.h, which contains just the types needed for syscallargs.h. Yes, there's only one now, but that may change and it's probably more likely to change if it'd be difficult to handle. :-)
Per discussion with matt at n dot o, add an include of satypes.h to sigtypes.h. Upcall handlers are kinda signal handlers, and signalling is the header file that's already included for syscallargs.h that closest matches SA.
This shaves about 3000 lines off of the diff of the branch relative to the base. That also represents about 18% of the total before this checkin.
I think this reduction is very good thing.
|
1.47.2.1 |
| 10-May-2008 |
wrstuden | Initial checkin of re-adding SA. Everything except kern_sa.c compiles in GENERIC for i386. This is still a work-in-progress, but this checkin covers most of the mechanical work (changing signalling to be able to accomidate SA's process-wide signalling and re-adding includes of sys/sa.h and savar.h). Subsequent changes will be much more interesting.
Also, kern_sa.c has received partial cleanup. There's still more to do, though.
|
1.48.14.1 |
| 21-Apr-2010 |
matt | sync to netbsd-5
|
1.48.10.1 |
| 23-Jul-2009 |
jym | Sync with HEAD.
|
1.48.6.1 |
| 17-Mar-2010 |
snj | Pull up following revision(s) (requested by he in ticket #1323): sys/compat/common/vfs_syscalls_30.c: revision 1.31 sys/compat/ibcs2/ibcs2_misc.c: revision 1.110 sys/compat/irix/irix_dirent.c: revision 1.24 sys/compat/linux/common/linux_file64.c: revision 1.50 sys/compat/linux/common/linux_misc.c: revision 1.214 sys/compat/linux32/common/linux32_dirent.c: revision 1.10 sys/compat/sunos/sunos_misc.c: revision 1.166 sys/compat/sunos32/sunos32_misc.c: revision 1.69 sys/compat/svr4/svr4_misc.c: revision 1.149 sys/compat/svr4_32/svr4_32_misc.c: revision 1.68 When implementing "read directory", when there are too many empty entries in a row, and we need to try to read the next block, and have passed a non-NULL cookie pointer to VOP_READDIR, ensure that we free the cookie buffer before re-doing VOP_READDIR, so that we don't leak memory. This fix is similar to nfs_serv.c revisions 1.115 + 1.124. This should fix the long-standing problem observed by e.g. using Linux- emulated programs to take backup of servers, which is one of the problems which were reported in PR#42661. Thanks to pooka@ for the hints for traversing the VOP* layer.
|
1.49.2.2 |
| 17-Aug-2010 |
uebayasi | Sync with HEAD.
|
1.49.2.1 |
| 30-Apr-2010 |
uebayasi | Sync with HEAD.
|
1.50.2.1 |
| 03-Jul-2010 |
rmind | sync with head
|
1.53.22.1 |
| 19-Aug-2017 |
snj | Pull up following revision(s) (requested by mrg in ticket #1483): sys/compat/common/vfs_syscalls_12.c: revision 1.34 sys/compat/svr4_32/svr4_32_misc.c: revision 1.78 sys/compat/sunos32/sunos32_misc.c: revision 1.78 sys/compat/linux/common/linux_misc.c: revision 1.239 sys/compat/osf1/osf1_file.c: revision 1.44 sys/compat/common/vfs_syscalls_43.c: revision 1.60 sys/compat/svr4/svr4_misc.c: revision 1.158 sys/compat/ibcs2/ibcs2_misc.c: revision 1.114 sys/compat/linux/common/linux_file64.c: revision 1.59 sys/compat/linux32/common/linux32_dirent.c: revision 1.18 sys/compat/sunos/sunos_misc.c: revision 1.171 Fail, don't panic, on bad dirents from file system. Controllable via puffs from userland. From Ilja Van Sprundel.
|
1.53.16.1 |
| 18-May-2014 |
rmind | sync with head
|
1.53.14.1 |
| 19-Aug-2017 |
snj | Pull up following revision(s) (requested by mrg in ticket #1483): sys/compat/common/vfs_syscalls_12.c: revision 1.34 sys/compat/svr4_32/svr4_32_misc.c: revision 1.78 sys/compat/sunos32/sunos32_misc.c: revision 1.78 sys/compat/linux/common/linux_misc.c: revision 1.239 sys/compat/osf1/osf1_file.c: revision 1.44 sys/compat/common/vfs_syscalls_43.c: revision 1.60 sys/compat/svr4/svr4_misc.c: revision 1.158 sys/compat/ibcs2/ibcs2_misc.c: revision 1.114 sys/compat/linux/common/linux_file64.c: revision 1.59 sys/compat/linux32/common/linux32_dirent.c: revision 1.18 sys/compat/sunos/sunos_misc.c: revision 1.171 Fail, don't panic, on bad dirents from file system. Controllable via puffs from userland. From Ilja Van Sprundel.
|
1.53.12.2 |
| 03-Dec-2017 |
jdolecek | update from HEAD
|
1.53.12.1 |
| 20-Aug-2014 |
tls | Rebase to HEAD as of a few days ago.
|
1.53.8.1 |
| 19-Aug-2017 |
snj | Pull up following revision(s) (requested by mrg in ticket #1483): sys/compat/common/vfs_syscalls_12.c: revision 1.34 sys/compat/svr4_32/svr4_32_misc.c: revision 1.78 sys/compat/sunos32/sunos32_misc.c: revision 1.78 sys/compat/linux/common/linux_misc.c: revision 1.239 sys/compat/osf1/osf1_file.c: revision 1.44 sys/compat/common/vfs_syscalls_43.c: revision 1.60 sys/compat/svr4/svr4_misc.c: revision 1.158 sys/compat/ibcs2/ibcs2_misc.c: revision 1.114 sys/compat/linux/common/linux_file64.c: revision 1.59 sys/compat/linux32/common/linux32_dirent.c: revision 1.18 sys/compat/sunos/sunos_misc.c: revision 1.171 Fail, don't panic, on bad dirents from file system. Controllable via puffs from userland. From Ilja Van Sprundel.
|
1.53.2.1 |
| 22-May-2014 |
yamt | sync with head.
for a reference, the tree before this commit was tagged as yamt-pagecache-tag8.
this commit was splitted into small chunks to avoid a limitation of cvs. ("Protocol error: too many arguments")
|
1.55.14.2 |
| 21-Jan-2020 |
martin | Pull up the following, requested by christos in ticket #1720:
sys/compat/common/kern_sig_43.c 1.36 sys/compat/linux/arch/amd64/linux_machdep.c 1.59 sys/compat/linux/common/linux_fcntl.h 1.18 sys/compat/linux/common/linux_file64.c 1.62 sys/compat/linux/common/linux_ipc.c 1.57 sys/compat/linux/common/linux_misc.c 1.243 sys/compat/linux/common/linux_signal.c 1.81 sys/compat/linux/common/linux_socket.c 1.149 (patch) sys/compat/linux/common/linux_socket.h 1.24 sys/compat/linux/common/linux_statfs.h 1.7 sys/compat/linux/common/linux_termios.c 1.38 sys/compat/linux/common/linux_termios.h 1.22 sys/compat/linux32/common/linux32_dirent.c 1.20 sys/compat/linux32/common/linux32_ioctl.c 1.14 sys/compat/linux32/common/linux32_misc.c 1.27 sys/compat/linux32/common/linux32_signal.c 1.20 sys/compat/linux32/common/linux32_sysinfo.c 1.8 sys/compat/linux32/common/linux32_termios.c 1.15 sys/compat/linux32/common/linux32_utsname.c 1.10 sys/compat/netbsd32/netbsd32_compat_20.c 1.39 sys/compat/netbsd32/netbsd32_compat_43.c 1.59 sys/compat/netbsd32/netbsd32_compat_50.c 1.44 sys/compat/ossaudio/ossaudio.c 1.75 sys/kern/sysv_shm.c 1.138 sys/miscfs/procfs/procfs_linux.c 1.75 (patch) sys/sys/shm.h 1.54 (patch)
Fix various info leaks, out of bound access, usage of uninitialized values and direct access to userland variables from kernel space and memory leaks in system calls implemented for the compatibility subsystems.
|
1.55.14.1 |
| 12-Aug-2017 |
snj | Pull up following revision(s) (requested by mrg in ticket #1479): sys/compat/common/vfs_syscalls_12.c: revision 1.34 sys/rump/kern/lib/libsys_sunos/rump_sunos_compat.c: revision 1.2 sys/compat/svr4_32/svr4_32_misc.c: revision 1.78 sys/compat/sunos32/sunos32_misc.c: revision 1.78 sys/compat/linux/common/linux_misc.c: revision 1.239 sys/compat/osf1/osf1_file.c: revision 1.44 sys/compat/common/vfs_syscalls_43.c: revision 1.60 sys/compat/svr4/svr4_misc.c: revision 1.158 sys/compat/ibcs2/ibcs2_misc.c: revision 1.114 sys/compat/linux/common/linux_file64.c: revision 1.59 sys/compat/linux32/common/linux32_dirent.c: revision 1.18 sys/compat/sunos/sunos_misc.c: revision 1.171 Fail, don't panic, on bad dirents from file system. Controllable via puffs from userland. From Ilja Van Sprundel.
|
1.55.10.1 |
| 20-Mar-2017 |
pgoyette | Sync with HEAD
|
1.55.8.1 |
| 12-Aug-2017 |
snj | Pull up following revision(s) (requested by mrg in ticket #1479): sys/compat/common/vfs_syscalls_12.c: revision 1.34 sys/rump/kern/lib/libsys_sunos/rump_sunos_compat.c: revision 1.2 sys/compat/svr4_32/svr4_32_misc.c: revision 1.78 sys/compat/sunos32/sunos32_misc.c: revision 1.78 sys/compat/linux/common/linux_misc.c: revision 1.239 sys/compat/osf1/osf1_file.c: revision 1.44 sys/compat/common/vfs_syscalls_43.c: revision 1.60 sys/compat/svr4/svr4_misc.c: revision 1.158 sys/compat/ibcs2/ibcs2_misc.c: revision 1.114 sys/compat/linux/common/linux_file64.c: revision 1.59 sys/compat/linux32/common/linux32_dirent.c: revision 1.18 sys/compat/sunos/sunos_misc.c: revision 1.171 Fail, don't panic, on bad dirents from file system. Controllable via puffs from userland. From Ilja Van Sprundel.
|
1.55.6.2 |
| 28-Aug-2017 |
skrll | Sync with HEAD
|
1.55.6.1 |
| 05-Feb-2017 |
skrll | Sync with HEAD
|
1.55.4.2 |
| 21-Jan-2020 |
martin | Pull up the following, requested by christos in ticket #1720:
sys/compat/common/kern_sig_43.c 1.36 sys/compat/linux/arch/amd64/linux_machdep.c 1.59 sys/compat/linux/common/linux_fcntl.h 1.18 sys/compat/linux/common/linux_file64.c 1.62 sys/compat/linux/common/linux_ipc.c 1.57 sys/compat/linux/common/linux_misc.c 1.243 sys/compat/linux/common/linux_signal.c 1.81 sys/compat/linux/common/linux_socket.c 1.149 (patch) sys/compat/linux/common/linux_socket.h 1.24 sys/compat/linux/common/linux_statfs.h 1.7 sys/compat/linux/common/linux_termios.c 1.38 sys/compat/linux/common/linux_termios.h 1.22 sys/compat/linux32/common/linux32_dirent.c 1.20 sys/compat/linux32/common/linux32_ioctl.c 1.14 sys/compat/linux32/common/linux32_misc.c 1.27 sys/compat/linux32/common/linux32_signal.c 1.20 sys/compat/linux32/common/linux32_sysinfo.c 1.8 sys/compat/linux32/common/linux32_termios.c 1.15 sys/compat/linux32/common/linux32_utsname.c 1.10 sys/compat/netbsd32/netbsd32_compat_20.c 1.39 sys/compat/netbsd32/netbsd32_compat_43.c 1.59 sys/compat/netbsd32/netbsd32_compat_50.c 1.44 sys/compat/ossaudio/ossaudio.c 1.75 sys/kern/sysv_shm.c 1.138 sys/miscfs/procfs/procfs_linux.c 1.75 (patch) sys/sys/shm.h 1.54 (patch)
Fix various info leaks, out of bound access, usage of uninitialized values and direct access to userland variables from kernel space and memory leaks in system calls implemented for the compatibility subsystems.
|
1.55.4.1 |
| 12-Aug-2017 |
snj | Pull up following revision(s) (requested by mrg in ticket #1479): sys/compat/common/vfs_syscalls_12.c: revision 1.34 sys/rump/kern/lib/libsys_sunos/rump_sunos_compat.c: revision 1.2 sys/compat/svr4_32/svr4_32_misc.c: revision 1.78 sys/compat/sunos32/sunos32_misc.c: revision 1.78 sys/compat/linux/common/linux_misc.c: revision 1.239 sys/compat/osf1/osf1_file.c: revision 1.44 sys/compat/common/vfs_syscalls_43.c: revision 1.60 sys/compat/svr4/svr4_misc.c: revision 1.158 sys/compat/ibcs2/ibcs2_misc.c: revision 1.114 sys/compat/linux/common/linux_file64.c: revision 1.59 sys/compat/linux32/common/linux32_dirent.c: revision 1.18 sys/compat/sunos/sunos_misc.c: revision 1.171 Fail, don't panic, on bad dirents from file system. Controllable via puffs from userland. From Ilja Van Sprundel.
|
1.57.2.1 |
| 21-Apr-2017 |
bouyer | Sync with HEAD
|
1.58.6.2 |
| 21-Jan-2020 |
martin | Pull up the following, requested by christos in ticket #1487:
sys/compat/common/kern_sig_43.c 1.36 sys/compat/linux/arch/amd64/linux_machdep.c 1.59 sys/compat/linux/common/linux_fcntl.h 1.18 sys/compat/linux/common/linux_file64.c 1.62 sys/compat/linux/common/linux_ipc.c 1.57 sys/compat/linux/common/linux_misc.c 1.243 sys/compat/linux/common/linux_signal.c 1.81 sys/compat/linux/common/linux_socket.c 1.149 sys/compat/linux/common/linux_socket.h 1.24 sys/compat/linux/common/linux_statfs.h 1.7 sys/compat/linux/common/linux_termios.c 1.38 sys/compat/linux/common/linux_termios.h 1.22 sys/compat/linux32/common/linux32_dirent.c 1.20 sys/compat/linux32/common/linux32_ioctl.c 1.14 sys/compat/linux32/common/linux32_misc.c 1.27 sys/compat/linux32/common/linux32_signal.c 1.20 sys/compat/linux32/common/linux32_sysinfo.c 1.8 sys/compat/linux32/common/linux32_termios.c 1.15 sys/compat/linux32/common/linux32_utsname.c 1.10 sys/compat/netbsd32/netbsd32_compat_20.c 1.39 sys/compat/netbsd32/netbsd32_compat_43.c 1.59 sys/compat/netbsd32/netbsd32_compat_50.c 1.44 sys/compat/ossaudio/ossaudio.c 1.75 sys/kern/sysv_shm.c 1.138 sys/miscfs/procfs/procfs_linux.c 1.75 (patch) sys/sys/shm.h 1.54
Fix various info leaks, out of bound access, usage of uninitialized values and direct access to userland variables from kernel space and memory leaks in system calls implemented for the compatibility subsystems.
|
1.58.6.1 |
| 09-Aug-2017 |
snj | Pull up following revision(s) (requested by spz in ticket #193): sys/compat/common/vfs_syscalls_12.c: revision 1.34 sys/rump/kern/lib/libsys_sunos/rump_sunos_compat.c: revision 1.2 sys/compat/svr4_32/svr4_32_misc.c: revision 1.78 sys/compat/sunos32/sunos32_misc.c: revision 1.78 sys/compat/linux/common/linux_misc.c: revision 1.239 sys/compat/osf1/osf1_file.c: revision 1.44 sys/compat/common/vfs_syscalls_43.c: revision 1.60 sys/compat/svr4/svr4_misc.c: revision 1.158 sys/compat/ibcs2/ibcs2_misc.c: revision 1.114 sys/compat/linux/common/linux_file64.c: revision 1.59 sys/compat/linux32/common/linux32_dirent.c: revision 1.18 sys/compat/sunos/sunos_misc.c: revision 1.171 Fail, don't panic, on bad dirents from file system. Controllable via puffs from userland. From Ilja Van Sprundel.
|
1.59.4.2 |
| 13-Apr-2020 |
martin | Mostly merge changes from HEAD upto 20200411
|
1.59.4.1 |
| 10-Jun-2019 |
christos | Sync with HEAD
|
1.59.2.1 |
| 06-Sep-2018 |
pgoyette | Sync with HEAD
Resolve a couple of conflicts (result of the uimin/uimax changes)
|
1.60.4.1 |
| 13-Sep-2019 |
martin | Pull up following revision(s) (requested by maxv in ticket #194):
sys/compat/linux/common/linux_socket.c: revision 1.146 sys/compat/linux/common/linux_socket.c: revision 1.147 sys/compat/linux/common/linux_socket.c: revision 1.148 sys/compat/linux/common/linux_socket.c: revision 1.149 sys/compat/linux/arch/amd64/linux_machdep.c: revision 1.59 sys/compat/linux32/common/linux32_sysinfo.c: revision 1.8 sys/kern/sysv_shm.c: revision 1.138 sys/compat/linux/common/linux_file64.c: revision 1.61 sys/compat/linux/common/linux_file64.c: revision 1.62 sys/compat/netbsd32/netbsd32_compat_43.c: revision 1.58 sys/compat/linux32/common/linux32_dirent.c: revision 1.20 sys/compat/linux32/common/linux32_utsname.c: revision 1.10 sys/compat/linux/common/linux_termios.h: revision 1.22 sys/compat/linux32/common/linux32_termios.c: revision 1.15 sys/compat/linux32/common/linux32_misc.c: revision 1.27 sys/compat/linux32/common/linux32_ioctl.c: revision 1.14 sys/compat/linux/common/linux_statfs.h: revision 1.7 sys/compat/linux/common/linux_ipc.c: revision 1.57 sys/compat/linux/common/linux_fcntl.h: revision 1.18 sys/compat/linux/common/linux_socket.h: revision 1.24 sys/sys/shm.h: revision 1.54 sys/compat/ossaudio/ossaudio.c: revision 1.75 sys/compat/linux32/common/linux32_signal.c: revision 1.20 sys/miscfs/procfs/procfs_linux.c: revision 1.75 sys/compat/linux/common/linux_signal.c: revision 1.81 sys/compat/linux/common/linux_termios.c: revision 1.38 sys/compat/linux/common/linux_misc.c: revision 1.241 sys/compat/linux/common/linux_misc.c: revision 1.242 sys/compat/linux/common/linux_misc.c: revision 1.243 sys/compat/linux/common/linux_misc.c: revision 1.244
Fix info leaks.
Fix stupid bugs in linux_sys_shmctl(): the index could be out of bound (page fault) and there was no proper locking. Maybe we should just remove LINUX_SHM_STAT, like compat_linux32.
Remove printf.
When dealing with an unknown value, set -1, to prevent (harmless) uninitialized accesses later.
Add a default case, don't call sys_ioctl() with an uninitialized 'com' argument.
Fix error handling, returns an errno, not -1.
Put the printf under DEBUG_LINUX.
Hum, don't forget the 'pid' argument, otherwise we're not gonna go very far.
Don't read data from userland directly. This simply does not work on any recent x86 CPU (thanks to SMAP) and all architectures that forbid direct access to userland from the kernel. But I guess no one noticed because no one ever uses compat_linux, right?
Hum, don't pass an mbuf to realloc(). Inspired from copyin32_msg_control().
Fix memory leak.
I don't see the point in having this useless printf, but add a '\n' to it, so that it at least displays useless stuff correctly.
Hum, remove incorrect assignment. Userland could have passed a smaller namelen, and the uninitialized bytes from sb_data were being used later in the network stack.
|