[LTP] [PATCH 4/4] syscalls/mlock202: Add new testcase
Xiao Yang
yangx.jy@cn.fujitsu.com
Thu Aug 30 09:41:09 CEST 2018
On 2018/08/29 20:44, Jan Stancek wrote:
> ----- Original Message -----
>> Check various errnos for mlock2(2) since kernel v2.6.9.
> mlock2() is available since Linux 4.4.
>
>> +static struct tcase {
>> + char **taddr;
>> + int flag;
>> + unsigned long *max_size;
>> + /* 1: nobody expected 0: root expected */
>> + int exp_user;
> I'd drop the "expected" prefix here, this isn't something syscall provides as "output".
Hi Jan,
OK, I will drop it.
>> + int exp_err;
>> +} tcases[] = {
>> + {&addr, -1, NULL, 0, EINVAL},
>> + {&addr, 0,&max_sz1, 1, ENOMEM},
>> + {&addr, 0,&max_sz2, 1, EPERM},
>> + {&unmapped_addr, 0, NULL, 0, ENOMEM},
>> +};
>> +
> ..
>> +static void setup(void)
>> +{
>> + pgsz = getpagesize();
>> + nobody = SAFE_GETPWNAM("nobody");
>> +
>> + addr = SAFE_MMAP(NULL, pgsz, PROT_WRITE,
>> + MAP_PRIVATE | MAP_ANONYMOUS, 0, 0);
>> + unmapped_addr = SAFE_MMAP(NULL, pgsz, PROT_READ,
>> + MAP_PRIVATE | MAP_ANONYMOUS, 0, 0);
>> + SAFE_MUNMAP(unmapped_addr, pgsz);
> I suggest larger map here (couple M) and pick address in middle.
> Single page can easily be mapped by glibc for some buffer.
OK, i will map a larger one and pick address in middle.
Thanks,
Xiao Yang
>> +
>> + max_sz1 = pgsz - 1;
>> +}
>> +
> Regards,
> Jan
>
>
>
More information about the ltp
mailing list