2 #-----------------------------------------------------------------------
3 # Copyright (c) 2000-2004 Silicon Graphics, Inc. All Rights Reserved.
4 # This program is free software; you can redistribute it and/or modify
5 # it under the terms of the GNU General Public License as published by
6 # the Free Software Foundation; either version 2 of the License, or
7 # (at your option) any later version.
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19 # Contact information: Silicon Graphics, Inc., 1500 Crittenden Lane,
20 # Mountain View, CA 94043, USA, or: http://www.sgi.com
21 #-----------------------------------------------------------------------
22 # common extended attribute and ACL support
24 # filesystems that want to test maximum supported acl counts need to
30 # CRC format filesystems have much larger ACL counts. The actual
31 # number is into the thousands, but testing that meany takes too
32 # long, so just test well past the old limit of 25.
33 xfs_info $TEST_DIR | _filter_mkfs > /dev/null 2> $tmp.info
36 if [ $_fs_has_crcs -eq 0 ]; then
51 _require_acl_get_max()
53 if [ $(_acl_get_max) -eq 0 ]; then
54 _notrun "$FSTYP does not define maximum ACL count"
58 # pick three unused user/group ids, store them as $acl[1-3]
62 eval `(_cat_passwd; _cat_group) | awk -F: '
66 for(i=1; i<1000000 && j<=3;i++){
68 printf "acl%d=%d;", j, i;
75 # filter for the acl ids selected above
80 -e "s/u:$acl1/u:id1/" \
81 -e "s/u:$acl2/u:id2/" \
82 -e "s/u:$acl3/u:id3/" \
83 -e "s/g:$acl1/g:id1/" \
84 -e "s/g:$acl2/g:id2/" \
85 -e "s/g:$acl3/g:id3/" \
86 -e "s/ $acl1 / id1 /" \
87 -e "s/ $acl2 / id2 /" \
94 -e "s/user:$acl1/user:id1/" \
95 -e "s/user:$acl2/user:id2/" \
96 -e "s/user:$acl3/user:id3/" \
97 -e "s/group:$acl1/group:id1/" \
98 -e "s/group:$acl2/group:id2/" \
99 -e "s/group:$acl3/group:id3/" \
100 -e "s/: $acl1/: id1/" \
101 -e "s/: $acl2/: id2/" \
102 -e "s/: $acl3/: id3/"
109 _ls_l -n $* | awk '{ print $1, $3, $4, $NF }' | _acl_filter_id
117 if [ $HOSTOS = "IRIX" ]; then
118 ls -dD $_file1 | _acl_filter_id
120 chacl -l $_file1 | _acl_filter_id
124 # create an ACL with n ACEs in it
129 acl='u::rwx,g::rwx,o::rwx,m::rwx' # 4 ace acl start
130 while [ $n -ne 0 ]; do
137 # filter user ace names to user ids
141 tmp_file=`mktemp /tmp/ace.XXXXXX`
143 (_cat_passwd; _cat_group) > $tmp_file
145 $AWK_PROG -v tmpfile=$tmp_file '
148 while ( getline <tmpfile > 0 ) {
152 /^user/ { if ($2 in idlist) sub($2, idlist[$2]); print; next}
153 /^u/ { if ($2 in idlist) sub($2, idlist[$2]); print; next}
154 /^default:user/ { if ($3 in idlist) sub($3, idlist[$3]); print; next}
160 _filter_aces_notypes()
162 tr '\[' '\012' | tr ']' '\012' | tr ',' '\012' | _filter_aces|\
163 sed -e 's/u:/user:/' -e 's/g:/group:/' -e 's/o:/other:/' -e 's/m:/mask:/'
168 if [ ! -x /bin/chacl -a ! -x /usr/bin/chacl -a ! -x /sbin/chacl ]; then
169 _notrun "chacl command not found"
173 # Test if chacl is able to list ACLs on the target filesystems. On really
174 # old kernels the system calls might not be implemented at all, but the
175 # more common case is that the tested filesystem simply doesn't support
178 touch $TEST_DIR/syscalltest
179 chacl -l $TEST_DIR/syscalltest > $TEST_DIR/syscalltest.out 2>&1
180 cat $TEST_DIR/syscalltest.out >> $seqres.full
182 if grep -q 'Function not implemented' $TEST_DIR/syscalltest.out; then
183 _notrun "kernel does not support ACLs"
185 if grep -q 'Operation not supported' $TEST_DIR/syscalltest.out; then
186 _notrun "ACLs not supported by this filesystem type: $FSTYP"
189 rm -f $TEST_DIR/syscalltest.out
196 ls -dD $file | _acl_filter_id
201 [ -n $ATTR_PROG ] || _notrun "attr command not found"
202 [ -n $GETFATTR_PROG ] || _notrun "getfattr command not found"
203 [ -n $SETFATTR_PROG ] || _notrun "setfattr command not found"
206 # Test if chacl is able to write an attribute on the target filesystems.
207 # On really old kernels the system calls might not be implemented at all,
208 # but the more common case is that the tested filesystem simply doesn't
209 # support attributes. Note that we can't simply list attributes as
210 # various security modules generate synthetic attributes not actually
213 touch $TEST_DIR/syscalltest
214 attr -s "user.xfstests" -V "attr" $TEST_DIR > $TEST_DIR/syscalltest.out 2>&1
215 cat $TEST_DIR/syscalltest.out >> $seqres.full
217 if grep -q 'Function not implemented' $TEST_DIR/syscalltest.out; then
218 _notrun "kernel does not support attrs"
220 if grep -q 'Operation not supported' $TEST_DIR/syscalltest.out; then
221 _notrun "attrs not supported by this filesystem type: $FSTYP"
224 rm -f $TEST_DIR/syscalltest.out
229 _scratch_mkfs_xfs_supported -i attr=1 >/dev/null 2>&1 \
230 || _notrun "attr v1 not supported on $SCRATCH_DEV"
233 # check if we support the noattr2 mount option
236 _scratch_mkfs_xfs > /dev/null 2>&1 \
237 || _fail "_scratch_mkfs_xfs failed on $SCRATCH_DEV"
238 _mount -o noattr2 $SCRATCH_DEV > /dev/null 2>&1 \
239 || _notrun "noattr2 mount option not supported on $SCRATCH_DEV"
243 # getfattr -R returns info in readdir order which varies from fs to fs.
244 # This sorts the output by filename
245 _sort_getfattr_output()
247 awk '{a[FNR]=$0}END{n = asort(a); for(i=1; i <= n; i++) print a[i]"\n"}' RS=''
250 # set maximum total attr space based on fs type
251 if [ "$FSTYP" == "xfs" -o "$FSTYP" == "udf" ]; then
253 else # Assume max ~1 block of attrs
254 BLOCK_SIZE=`stat -f $TEST_DIR | grep "Block size" | cut -d " " -f3`
255 # user.attribute_XXX="value.XXX" is about 32 bytes; leave some overhead
256 let MAX_ATTRS=$BLOCK_SIZE/40
261 # Set max attr value size based on fs type
262 if [ "$FSTYP" == "xfs" -o "$FSTYP" == "udf" -o "$FSTYP" == "btrfs" ]; then
264 else # Assume max ~1 block of attrs
265 BLOCK_SIZE=`stat -f $TEST_DIR | grep "Block size" | cut -d " " -f3`
266 # leave a little overhead
267 let MAX_ATTRVAL_SIZE=$BLOCK_SIZE-256
270 export MAX_ATTRVAL_SIZE
271 # make sure this script returns success