Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 12 Jan 2001 16:02:41 -0800 (PST)
From:      Matt Dillon <dillon@earth.backplane.com>
To:        Andrew Gallatin <gallatin@cs.duke.edu>
Cc:        freebsd-current@FreeBSD.ORG, "'Alfred Perlstein'" <bright@wintelcom.net>
Subject:   Re: RE: Running Linux kernel modules.
Message-ID:  <200101130002.f0D02fk16650@earth.backplane.com>
References:  <01C07BF3.695D3780.ggross@symark.com> <14942.32188.899333.434988@grasshopper.cs.duke.edu>

next in thread | previous in thread | raw e-mail | index | archive | help
:To handle the multiple open problem, I'm overloading the open and
:close system calls.  Upon open, I call the native open, then I grovel
:around in the process' open file table looking for my special file.
:When I find it, I mark fp->f_nextread with a magic number, then store
:a pointer to the per-open private data in fp->f_offset.  On close, I
:go grovelling again.  I deallocate the private data, clear the magic
:number, and call the system close function.  I've also got an
:at_exit() hook that does much the same thing.

    Wait a sec... f_nextread and f_offset can be messed around with
    by the user process, what prevents the user process from screwing
    up your kernel data pointer?

    Why not just track the opens independantly in the overloading code?

					-Matt



To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-current" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200101130002.f0D02fk16650>