blob: 84ee89d85a1bed233d39de10d58311d99aa58fc8 [file] [log] [blame]
Masatake YAMATO6077ad82014-12-24 20:59:32 +09001#!/bin/sh
Dmitry V. Levin38a34c92015-12-17 17:56:48 +00002#
Masatake YAMATO6077ad82014-12-24 20:59:32 +09003# Check decoding of address information (inode[->peer][,path])
4# associated with unix domain socket descriptors.
Dmitry V. Levin38a34c92015-12-17 17:56:48 +00005#
6# Copyright (c) 2014 Masatake YAMATO <yamato@redhat.com>
7# Copyright (c) 2014-2015 Dmitry V. Levin <ldv@altlinux.org>
8# All rights reserved.
9#
10# Redistribution and use in source and binary forms, with or without
11# modification, are permitted provided that the following conditions
12# are met:
13# 1. Redistributions of source code must retain the above copyright
14# notice, this list of conditions and the following disclaimer.
15# 2. Redistributions in binary form must reproduce the above copyright
16# notice, this list of conditions and the following disclaimer in the
17# documentation and/or other materials provided with the distribution.
18# 3. The name of the author may not be used to endorse or promote products
19# derived from this software without specific prior written permission.
20#
21# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Masatake YAMATO6077ad82014-12-24 20:59:32 +090031
32. "${srcdir=.}/init.sh"
33
34# strace -yy is implemented using /proc/self/fd
35[ -d /proc/self/fd/ ] ||
36 framework_skip_ '/proc/self/fd/ is not available'
37
Masatake YAMATO6077ad82014-12-24 20:59:32 +090038check_prog sed
39
Dmitry V. Levin8f546642015-03-17 17:07:57 +000040run_prog ./netlink_unix_diag
Dmitry V. Levinc9cc4cb2015-01-07 20:14:19 +000041addr=unix-yy-local-stream
Dmitry V. Levin8f546642015-03-17 17:07:57 +000042run_prog ./net-accept-connect $addr
43run_strace_merge -yy -eclose,network $args
Masatake YAMATO6077ad82014-12-24 20:59:32 +090044
Dmitry V. Levin8f546642015-03-17 17:07:57 +000045child="$(sed -rn '/SIGCHLD/ s/^.*, si_pid=([1-9][0-9]*), .*/\1/p' "$LOG")"
46[ -n "$child" ] ||
47 dump_log_and_fail_with 'failed to find pid of child process'
Masatake YAMATO6077ad82014-12-24 20:59:32 +090048
Dmitry V. Levin8f546642015-03-17 17:07:57 +000049rm -f "$LOG"-*
50sed -rn "/^$child"' /!d; / socket\(/,$ s/^[0-9]+ +[^ ]+ (.+)/\1/p' "$LOG" > "$LOG"-connect &&
51sed -rn "/^$child"' /d; /SIGCHLD/d; / socket\(/,$ s/^[0-9]+ +[^ ]+ (.+)/\1/p' "$LOG" > "$LOG"-accept ||
52 dump_log_and_fail_with 'failed to separate logs'
Masatake YAMATO6077ad82014-12-24 20:59:32 +090053
Dmitry V. Levin8f546642015-03-17 17:07:57 +000054match_awk "$LOG-connect" "$srcdir"/unix-yy-connect.awk "$STRACE $args connect output mismatch" -v addr=$addr
55match_awk "$LOG-accept" "$srcdir"/unix-yy-accept.awk "$STRACE $args accept output mismatch" -v addr=$addr
Masatake YAMATO6077ad82014-12-24 20:59:32 +090056
Dmitry V. Levine8199b22015-11-27 17:24:46 +000057rm -f "$LOG"-connect "$LOG"-accept
58
Masatake YAMATO6077ad82014-12-24 20:59:32 +090059exit 0