public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* Re: [PATCH/2.4]: do_write_mem() return value check
       [not found] <200403231707.14088.blaisorblade_work@yahoo.it>
@ 2004-03-25 20:52 ` Marcelo Tosatti
  0 siblings, 0 replies; 2+ messages in thread
From: Marcelo Tosatti @ 2004-03-25 20:52 UTC (permalink / raw)
  To: BlaisorBlade; +Cc: linux-kernel, akpm

On Wed, Mar 24, 2004 at 07:59:01PM +0100, BlaisorBlade wrote:
> From: Andrew Morton, and me (I did a first fix for 2.6 and sent to him, he 
> checked everything and committed it and I changed the trivial bits for 2.4).
> 
> - remove unused `file *' arg from do_write_mem()
> 
> - Add checking for copy_from_user() failures in do_write_mem()
> 
> (Note: /dev/kmem can be written to only by root, so this *cannot* have 
> security implications)
> 
> - Return correct value from kmem writes() when a fault is encountered.  A
>   write()-style syscall's return values are:
> 
>    0 when nothing was written and there was no error (someone tried to
>    write zero bytes)
> 
>    >0: the number of bytes copied, whether or not there was an error. 
>    Userspace detects errors by noting that the write() return value is less
>    than was requested.
> 
>    <0: there was an error and no bytes were copied
> 
> TODO: Do the same changes for read_mem() and read_kmem(). The code is more 
> messy so I must create do_read_mem() to avoid clumsy counting; I will post the 
> patch first for 2.6.

Hi Paolo, 

This is nice -- although I see it as a 2.6 cleanup only.

Do you actually have any practical problem caused by the current broken 
"always return -EFAULT" ? 

Otherwise leave it for 2.6.

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [PATCH/2.4]: do_write_mem() return value check
       [not found] <20040326033339.GD1997@logos.cnet>
@ 2004-03-26 18:16 ` BlaisorBlade
  0 siblings, 0 replies; 2+ messages in thread
From: BlaisorBlade @ 2004-03-26 18:16 UTC (permalink / raw)
  To: Marcelo Tosatti; +Cc: linux-kernel

Alle 04:33, venerdì 26 marzo 2004, Marcelo Tosatti ha scritto:
> On Wed, Mar 24, 2004 at 07:59:01PM +0100, BlaisorBlade wrote:
> > From: Andrew Morton, and me (I did a first fix for 2.6 and sent to him,
> > he checked everything and committed it and I changed the trivial bits for
> > 2.4).

> Do you actually have any practical problem caused by the current broken
> "always return -EFAULT" ?

It is not only that, there can be also data corruption:

- The  "always return -EFAULT" one is a little bug, so you can discard the 
first and third hunk which fix that; anyway, it was Andrew Morton who noticed 
that, so I've no idea (I agree with you but I'm a kernel newbie). Note I 
posted a 2nd version of the patch which fixes a bug in the third hunk (see at 
the end).

- BUT in the hunk below (the 2nd in the patch), without the patch, the var 
"wrote" can be == -EFAULT and WE CAN DO
		p += -EFAULT, 
                buf += -EFAULT;

so that we can read, afterwards, some bytes of junk from buf - EFAULT and put 
them into p - EFAULT, *corrupting memory* !!!!

> > - Add checking for copy_from_user() failures in do_write_mem()

        if (p < (unsigned long) high_memory) {
+               ssize_t written;
+
                wrote = count;
                if (count > (unsigned long) high_memory - p)
                        wrote = (unsigned long) high_memory - p;

-               wrote = do_write_mem(file, (void*)p, p, buf, wrote, ppos);
+               written = do_write_mem((void*)p, p, buf, wrote, ppos);
+               if (written != wrote)
+                       return written;
+               wrote = written;

                p += wrote;
                buf += -EFAULT;


Fix in the second version of the patch, for the 3rd hunk:
- Fix this line:
+                              unwritten = copy_from_user(kbuf, buf, len);
+                              if (unwritten != len) {
					[... error handling]
to this:
+                              unwritten = copy_from_user(kbuf, buf, len);
+                              if (unwritten != 0) {
					[...error handling]
-- 
Paolo Giarrusso, aka Blaisorblade
Linux registered user n. 292729


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2004-03-27  4:40 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <200403231707.14088.blaisorblade_work@yahoo.it>
2004-03-25 20:52 ` [PATCH/2.4]: do_write_mem() return value check Marcelo Tosatti
     [not found] <20040326033339.GD1997@logos.cnet>
2004-03-26 18:16 ` BlaisorBlade

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox