Call for testing: OpenSSH 6.8
Tom G. Christensen
tgc at jupiterrise.com
Thu Feb 26 08:55:59 AEDT 2015
On 24/02/15 21:56, Tim Rice wrote:
> On Wed, 25 Feb 2015, Damien Miller wrote:
>
> | On Tue, 24 Feb 2015, Tom G. Christensen wrote:
> |
> | > I've switched to HEAD in the git repo and it now builds on Solaris
> | > 2.6, 7, 8 and 9 but the testsuite still cannot be built due to the
> | > missing <err.h>.
>
> The err.h issue is fixes but there still msghdr structure differences
> to deal with.
>
Yes I saw that later.
The testsuite build fails on Solaris 2.6 thusly:
regress/netcat.c: In function 'timeout_connect':
regress/netcat.c:703: warning: passing argument 2 of 'connect' discards
qualifiers from pointer target type
regress/netcat.c:709: warning: passing argument 4 of 'getsockopt' from
incompatible pointer type
regress/netcat.c: In function 'local_listen':
regress/netcat.c:735: warning: unused variable 'x'
regress/netcat.c:735: warning: unused variable 'ret'
regress/netcat.c: In function 'fdpass':
regress/netcat.c:1037: error: 'struct msghdr' has no member named
'msg_control'
regress/netcat.c:1038: error: 'struct msghdr' has no member named
'msg_controllen'
regress/netcat.c:1039: error: 'struct msghdr' has no member named
'msg_controllen'
regress/netcat.c:1039: error: 'struct msghdr' has no member named
'msg_control'
regress/netcat.c: In function 'set_common_sockopts':
regress/netcat.c:1196: warning: passing argument 4 of 'setsockopt' from
incompatible pointer type
regress/netcat.c:1201: warning: passing argument 4 of 'setsockopt' from
incompatible pointer type
regress/netcat.c:1206: warning: passing argument 4 of 'setsockopt' from
incompatible pointer type
regress/netcat.c:1211: warning: passing argument 4 of 'setsockopt' from
incompatible pointer type
regress/netcat.c: In function 'decode_addrport':
regress/netcat.c:1419: warning: comparison between signed and unsigned
make: *** [regress/netcat] Error 1
I guess that is what you meant about structure differences.
It looks like on Solaris I can choose between msg_accrights* or
msg_control*/msg_flags in struct msghdr.
The latter requires _XOPEN_SOURCE and _XOPEN_SOURCE_EXTENDED which will
also require __EXTENSIONS__ or other useful things suddenly go away.
Building openssh with CC="gcc -D__EXTENSIONS__ -D_XOPEN_SOURCE
-D_XOPEN_SOURCE_EXTENDED" is possible (tested only on Solaris 9 so far).
Unfortunately now that I can finally run the testsuite I see ssh-keygen
dumps core in keygen-change.sh but all tests before that passes.
$ gdb ssh-keygen
GNU gdb (GDB) 7.8
...
Reading symbols from ssh-keygen...done.
(gdb) core regress/core
[New LWP 1]
Core was generated by
`/export/home/tgc/buildpkg/openssh/src/openssh-git/ssh-keygen -p -P
secret1 -N 2'.
Program terminated with signal SIGSEGV, Segmentation fault.
#0 0xfedb4b14 in strlen () from /usr/lib/libc.so.1
(gdb) bt
#0 0xfedb4b14 in strlen () from /usr/lib/libc.so.1
#1 0xfee07a20 in _doprnt () from /usr/lib/libc.so.1
#2 0xfee095e0 in printf () from /usr/lib/libc.so.1
#3 0x000546b0 in do_change_passphrase (pw=pw at entry=0x92954) at
ssh-keygen.c:1279
#4 0x00059420 in main (argc=0, argv=0xffbfe664) at ssh-keygen.c:2530
(gdb) fram 3
#3 0x000546b0 in do_change_passphrase (pw=pw at entry=0x92954) at
ssh-keygen.c:1279
1279 printf("Key has comment '%s'\n", comment);
(gdb) print comment
$1 = 0x0
(gdb)
I've not had time to look into this further and also I've not verified
if this happens without setting CC.
-tgc
More information about the openssh-unix-dev
mailing list