* [LTP] [PATCH] setdomainname: use strlen() to get length of string
@ 2019-07-23 10:28 Li Wang
2019-07-23 10:52 ` Xiao Yang
0 siblings, 1 reply; 3+ messages in thread
From: Li Wang @ 2019-07-23 10:28 UTC (permalink / raw)
To: ltp
The sizeof(new) is only to get the size of char *, and it's not corret to pass
it as 'len' in setdomainname(). Here replace by strlen() to get the correct number
of characters for string.
On x86_64, we get this failures if the LTP compilied in 32bit.
-----Error Log-----
setdomainname.h:24: INFO: Testing libc setdomainname()
setdomainname01.c:24: FAIL: getdomainname() returned wrong domainname: 'test'
setdomainname.h:27: INFO: Testing __NR_setdomainname syscall
setdomainname01.c:24: FAIL: getdomainname() returned wrong domainname: 'test'
-------------------
Signed-off-by: Li Wang <liwang@redhat.com>
Cc: Petr Vorel <pvorel@suse.cz>
---
testcases/kernel/syscalls/setdomainname/setdomainname01.c | 2 +-
testcases/kernel/syscalls/setdomainname/setdomainname03.c | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/testcases/kernel/syscalls/setdomainname/setdomainname01.c b/testcases/kernel/syscalls/setdomainname/setdomainname01.c
index 57d58ab42..1731af733 100644
--- a/testcases/kernel/syscalls/setdomainname/setdomainname01.c
+++ b/testcases/kernel/syscalls/setdomainname/setdomainname01.c
@@ -12,7 +12,7 @@ static void do_test(void)
char *new = TST_VALID_DOMAIN_NAME;
static char tmp[_UTSNAME_DOMAIN_LENGTH];
- TEST(do_setdomainname(new, sizeof(new)));
+ TEST(do_setdomainname(new, strlen(new)));
if (TST_RET != 0)
tst_brk(TFAIL | TTERRNO, "setdomainname() failed: %d", TST_ERR);
diff --git a/testcases/kernel/syscalls/setdomainname/setdomainname03.c b/testcases/kernel/syscalls/setdomainname/setdomainname03.c
index e53ea8806..b8d17d8da 100644
--- a/testcases/kernel/syscalls/setdomainname/setdomainname03.c
+++ b/testcases/kernel/syscalls/setdomainname/setdomainname03.c
@@ -16,7 +16,7 @@ static void do_test(void)
{
char *new = TST_VALID_DOMAIN_NAME;
- TEST(do_setdomainname(new, sizeof(new)));
+ TEST(do_setdomainname(new, strlen(new)));
if (TST_RET != -1) {
tst_res(TFAIL, "unexpected exit code: %ld", TST_RET);
--
2.20.1
^ permalink raw reply related [flat|nested] 3+ messages in thread
* [LTP] [PATCH] setdomainname: use strlen() to get length of string
2019-07-23 10:28 [LTP] [PATCH] setdomainname: use strlen() to get length of string Li Wang
@ 2019-07-23 10:52 ` Xiao Yang
2019-07-24 8:38 ` Petr Vorel
0 siblings, 1 reply; 3+ messages in thread
From: Xiao Yang @ 2019-07-23 10:52 UTC (permalink / raw)
To: ltp
On 2019/07/23 18:28, Li Wang wrote:
> The sizeof(new) is only to get the size of char *, and it's not corret to pass
> it as 'len' in setdomainname(). Here replace by strlen() to get the correct number
> of characters for string.
Hi Li,
As setdomainname(2) manpage mentions, name does not require a
terminating null byte.
It looks good to me. :-)
Best Regards,
Xiao Yang
> On x86_64, we get this failures if the LTP compilied in 32bit.
>
> -----Error Log-----
> setdomainname.h:24: INFO: Testing libc setdomainname()
> setdomainname01.c:24: FAIL: getdomainname() returned wrong domainname: 'test'
> setdomainname.h:27: INFO: Testing __NR_setdomainname syscall
> setdomainname01.c:24: FAIL: getdomainname() returned wrong domainname: 'test'
> -------------------
>
> Signed-off-by: Li Wang<liwang@redhat.com>
> Cc: Petr Vorel<pvorel@suse.cz>
> ---
> testcases/kernel/syscalls/setdomainname/setdomainname01.c | 2 +-
> testcases/kernel/syscalls/setdomainname/setdomainname03.c | 2 +-
> 2 files changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/testcases/kernel/syscalls/setdomainname/setdomainname01.c b/testcases/kernel/syscalls/setdomainname/setdomainname01.c
> index 57d58ab42..1731af733 100644
> --- a/testcases/kernel/syscalls/setdomainname/setdomainname01.c
> +++ b/testcases/kernel/syscalls/setdomainname/setdomainname01.c
> @@ -12,7 +12,7 @@ static void do_test(void)
> char *new = TST_VALID_DOMAIN_NAME;
> static char tmp[_UTSNAME_DOMAIN_LENGTH];
>
> - TEST(do_setdomainname(new, sizeof(new)));
> + TEST(do_setdomainname(new, strlen(new)));
>
> if (TST_RET != 0)
> tst_brk(TFAIL | TTERRNO, "setdomainname() failed: %d", TST_ERR);
> diff --git a/testcases/kernel/syscalls/setdomainname/setdomainname03.c b/testcases/kernel/syscalls/setdomainname/setdomainname03.c
> index e53ea8806..b8d17d8da 100644
> --- a/testcases/kernel/syscalls/setdomainname/setdomainname03.c
> +++ b/testcases/kernel/syscalls/setdomainname/setdomainname03.c
> @@ -16,7 +16,7 @@ static void do_test(void)
> {
> char *new = TST_VALID_DOMAIN_NAME;
>
> - TEST(do_setdomainname(new, sizeof(new)));
> + TEST(do_setdomainname(new, strlen(new)));
>
> if (TST_RET != -1) {
> tst_res(TFAIL, "unexpected exit code: %ld", TST_RET);
^ permalink raw reply [flat|nested] 3+ messages in thread
* [LTP] [PATCH] setdomainname: use strlen() to get length of string
2019-07-23 10:52 ` Xiao Yang
@ 2019-07-24 8:38 ` Petr Vorel
0 siblings, 0 replies; 3+ messages in thread
From: Petr Vorel @ 2019-07-24 8:38 UTC (permalink / raw)
To: ltp
Hi Li,
> On 2019/07/23 18:28, Li Wang wrote:
> > The sizeof(new) is only to get the size of char *, and it's not corret to pass
> > it as 'len' in setdomainname(). Here replace by strlen() to get the correct number
> > of characters for string.
> Hi Li,
> As setdomainname(2) manpage mentions, name does not require a terminating
> null byte.
> It looks good to me. :-)
> Best Regards,
> Xiao Yang
> > On x86_64, we get this failures if the LTP compilied in 32bit.
> > -----Error Log-----
> > setdomainname.h:24: INFO: Testing libc setdomainname()
> > setdomainname01.c:24: FAIL: getdomainname() returned wrong domainname: 'test'
> > setdomainname.h:27: INFO: Testing __NR_setdomainname syscall
> > setdomainname01.c:24: FAIL: getdomainname() returned wrong domainname: 'test'
> > -------------------
Thanks for fixing it and sorry for introducing obvious error.
Merged into master.
Kind regards,
Petr
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2019-07-24 8:38 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-07-23 10:28 [LTP] [PATCH] setdomainname: use strlen() to get length of string Li Wang
2019-07-23 10:52 ` Xiao Yang
2019-07-24 8:38 ` Petr Vorel
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.