Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 25 Jul 2005 17:27:45 +0300
From:      Giorgos Keramidas <keramida@freebsd.org>
To:        Felix-KM <Felix-KM@yandex.ru>
Cc:        NKoch@demig.de, freebsd-hackers@freebsd.org
Subject:   Re: how to use the function copyout()
Message-ID:  <20050725142745.GA26647@beatrix.daedalusnetworks.priv>
In-Reply-To: <42E4F3AD.000001.28235@colgate.yandex.ru>
References:  <000101c5911b$62441260$4801a8c0@ws-ew-3.W2KDEMIG> <42E4F3AD.000001.28235@colgate.yandex.ru>

next in thread | previous in thread | raw e-mail | index | archive | help
On 2005-07-25 18:14, Felix-KM <Felix-KM@yandex.ru> wrote:
> >I have no idea if it is possible for ioctls to have mapped more than
> >a few 100 bytes for data exchange.  You should use read and uiomove()
> >instead.
> 
> So if I get it right, it's impossible in FreeBSD to gain access to
> 64KB of user's program memory with ioctl?
> 
> My situation is this - I have a device driver for Linux. My task is
> port it as it is (1:1) into FreeBSD.
> 
> In the Linux driver Ioctl is realized with the macroses _put_user
> _get_user all over it. As I understand in FreeBSD their analogues are
> functions described in store(9), copy(9) and fetch(9).
>
> So the problem is that in my user program an array short unsigned int
> Data[32768] is defined. I need to gain access to the array(to each
> element of it) from device driver with Ioctl handler.
>
> Is it possible to do? If yes, then how it can be done?

A better alternative that doesn't involve copying huge amounts of data
from userlevel to kernel space and vice versa is probably to pass just
the address of the area with an ioctl() and then map the appropriate
pages from the address space of the user process to an area where the
kernel can access the data directly?




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