On Thursday 25 June 2009 6:25:31 pm Alexander Best wrote:
> hi there,
> 
> i'm currently playing a bit with the linux test project (ltp). it seems the
> linux syscall modify_ldt() isn't implemented correctly. the following code
> should set errno to ENOSYS, but instead EINVAL is being returned:

It looks like this should fix it:

--- //depot/vendor/freebsd/src/sys/i386/linux/linux_machdep.c   2009/02/18 
16:15:14
+++ //depot/user/jhb/acpipci/i386/linux/linux_machdep.c 2009/06/26 14:32:55
@@ -866,9 +866,6 @@
        union descriptor desc;
        int size, written;
 
-       if (uap->ptr == NULL)
-               return (EINVAL);
-
        switch (uap->func) {
        case 0x00: /* read_ldt */
                ldt.start = 0;
@@ -911,7 +908,7 @@
                error = i386_set_ldt(td, &ldt, &desc);
                break;
        default:
-               error = EINVAL;
+               error = ENOSYS;
                break;
        }
 

-- 
John Baldwin
_______________________________________________
[email protected] mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "[email protected]"

Reply via email to