Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751467AbdGQUud (ORCPT ); Mon, 17 Jul 2017 16:50:33 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:34693 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751334AbdGQUu3 (ORCPT ); Mon, 17 Jul 2017 16:50:29 -0400 Subject: Re: [PATCH v2] xattr: Enable security.capability in user namespaces To: Vivek Goyal , Stefan Berger References: <1499785511-17192-1-git-send-email-stefanb@linux.vnet.ibm.com> <1499785511-17192-2-git-send-email-stefanb@linux.vnet.ibm.com> <20170717185811.GC15794@redhat.com> Cc: ebiederm@xmission.com, containers@lists.linux-foundation.org, lkp@01.org, linux-kernel@vger.kernel.org, zohar@linux.vnet.ibm.com, tycho@docker.com, serge@hallyn.com, James.Bottomley@HansenPartnership.com, christian.brauner@mailbox.org, amir73il@gmail.com, linux-security-module@vger.kernel.org, casey@schaufler-ca.com From: Stefan Berger Date: Mon, 17 Jul 2017 16:50:22 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.4.0 MIME-Version: 1.0 In-Reply-To: <20170717185811.GC15794@redhat.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit X-TM-AS-GCONF: 00 x-cbid: 17071720-0024-0000-0000-000002B19103 X-IBM-SpamModules-Scores: X-IBM-SpamModules-Versions: BY=3.00007379; HX=3.00000241; KW=3.00000007; PH=3.00000004; SC=3.00000214; SDB=6.00889009; UDB=6.00444021; IPR=6.00669182; BA=6.00005476; NDR=6.00000001; ZLA=6.00000005; ZF=6.00000009; ZB=6.00000000; ZP=6.00000000; ZH=6.00000000; ZU=6.00000002; MB=3.00016252; XFM=3.00000015; UTC=2017-07-17 20:50:27 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 17071720-0025-0000-0000-000044C96E97 Message-Id: <7a39e8a6-a33b-f6a8-3fd5-6211c075ab91@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-07-17_16:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 suspectscore=0 malwarescore=0 phishscore=0 adultscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1706020000 definitions=main-1707170336 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2692 Lines: 68 On 07/17/2017 02:58 PM, Vivek Goyal wrote: > On Tue, Jul 11, 2017 at 11:05:11AM -0400, Stefan Berger wrote: > > [..] >> +/* >> + * xattr_list_userns_rewrite - Rewrite list of xattr names for user namespaces >> + * or determine needed size for attribute list >> + * in case size == 0 >> + * >> + * In a user namespace we do not present all extended attributes to the >> + * user. We filter out those that are in the list of userns supported xattr. >> + * Besides that we filter out those with @uid= when there is no mapping >> + * for that uid in the current user namespace. >> + * >> + * @list: list of 0-byte separated xattr names >> + * @size: the size of the list; may be 0 to determine needed list size >> + * @list_maxlen: allocated buffer size of list >> + */ >> +static ssize_t >> +xattr_list_userns_rewrite(char *list, ssize_t size, size_t list_maxlen) >> +{ >> + char *nlist = NULL; >> + size_t s_off, len, nlen; >> + ssize_t d_off; >> + char *name, *newname; >> + >> + if (!list || size < 0 || current_user_ns() == &init_user_ns) > size will never be less than 0 here. Only caller calls this function only > if size is >0. So can we remove this? Correct. > > What about case of "!list". So if user space called listxattr(foo, NULL, > 0), we want to return the size of buffer as if all the xattrs will be > returned to user space. But in practice we probably will filter out some > xattrs so actually returned string will be smaller than size reported > previously. This case of size=0 is a problem in userns. Depending on the mapping of the userid's the list can expand. A security.foo@uid=100 can become security.foo@uid=100000, if the mapping is set up so that uid 100 on the host becomes uid 100000 inside the container. So for now we only have security.capability and the way I solved this is by allocating a 65k buffer when calling from a userns. In this buffer where we gather the xattr names and then walk them to determine the size that's needed for the buffer by simulating the rewriting. It's not nice but I don't know of any other solution. > > Looks like that's the intent of "!list" condition here. Just wanted to > make sure, hence asking. Thanks for asking. I thought I had this case covered, but obviously I did not. > > BTW, I am testing this with overlayfs and trying to figure out if > switching of creds will create issues. Simple operations like listxattr > and getxattr and setxattr so far worked for me. And reason seems to be > that name transformation we are doing in top layer based on creds of > caller (and not based on creds of mounter). > > Vivek > Stefan