Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp277919ybt; Thu, 25 Jun 2020 22:18:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx+oUzNZfyIgrN2IcejIKa+VxYEZeRaAf9nfPbuws2W2U1inFYnpQOqwObL567ibvMlpH/1 X-Received: by 2002:a17:906:2bc2:: with SMTP id n2mr997661ejg.115.1593148686561; Thu, 25 Jun 2020 22:18:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593148686; cv=none; d=google.com; s=arc-20160816; b=KqiBdbuEUN0RgOFOAu02i2Wgd4ZnOgxSYP7Cg+wJdSxuCiN6deauJYyWwqaMVJ30KC ZdhhUsdx6No0mbFPwOkj7Dk6ueppF8vPrptUIye+w4KXvp67N+lhPUYNn8zvj8dHRL0D e5+acJnq3CLSLYAEhPbLi2Ss8iA4rCV38uCasSJ+Z/7im1CsMqYjktjwBYvqQ0w3HrO7 VihbkWSeyBgd6dd4IP98/cnCXPO4k4NCP4oDXK5Rz3IaZKuFWdqHuO6sG6KrXwFyhFWV Rw6RiXKP02+klgAG9BkQx4w4x9SurgSLJORR9z9qiyr5excWHNh1JAsss98mb526BFe8 Btbw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=QlzbbRoUsiNgCT+vaniYsWp4jyroliVG1Gc8oOdbYFc=; b=z5ECs0qZlePnYFOUeMlnPNmyNfwe6OkAUp0szUt8+shWfgtUD5bqLr5U5sF5LDgzts bvOuNWiMX/GoGAZ1O4/7TXrLoxo1h38ByLgz6oQZxV9IaCMpHOLfcTReeH1UkYONDfVl LZFMfsywD4tEiQnqdJmFhR3ZAlXZgj81jmh156evgsCS3UxSNLccCBR0fgu2U0DAXmI0 y99KvsTeXpIa/EU7zTT6mZ20LtzQhIspOVa7ZnmX6WOSvfX2dH6cFAsNxPTUGglt8EY9 3fjCAhf/fsmile0U/gNBiXJ8E/oDsLI6jA+mqq0sQdaEU2r/F1il6ZubUwaiT/HS8Uzz MNqQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=ovzR0esJ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s14si4671091ejx.43.2020.06.25.22.17.42; Thu, 25 Jun 2020 22:18:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=ovzR0esJ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726929AbgFZFN3 (ORCPT + 99 others); Fri, 26 Jun 2020 01:13:29 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42286 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726908AbgFZFN3 (ORCPT ); Fri, 26 Jun 2020 01:13:29 -0400 Received: from mail-lf1-x144.google.com (mail-lf1-x144.google.com [IPv6:2a00:1450:4864:20::144]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B6A25C08C5DB for ; Thu, 25 Jun 2020 22:13:28 -0700 (PDT) Received: by mail-lf1-x144.google.com with SMTP id t9so4446916lfl.5 for ; Thu, 25 Jun 2020 22:13:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=QlzbbRoUsiNgCT+vaniYsWp4jyroliVG1Gc8oOdbYFc=; b=ovzR0esJWDDdDFb0jyp9YafS2plBJiJOi/tQHePW6RnDCVpGvwaXPT2LuDIrUgc3q2 19hx1drG3bg59u5lR7vRrAY6Nc3AUcx+SA/aJCuaCCFTu6aQdtWyThAj08WHnhyRw9Wh djgKIGc1yRDJDXqra3ydGeqbRZMcEZFebg+jyQ4oWw0einDd3cg+CJMMY2689VPNftDy KY4yrmpnhxAj1bfFechr6cP9x/fFBTtyBayKVePsUXqf/2OZ4PJ67B1KUbE2mAg7BxfK mB/Qg0/3cqSxnvejiVmmjeA9fcct413ZTfYjwUWRtxtT6icZvCUAo4HVFq7TgeRGMsn9 7Cgw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=QlzbbRoUsiNgCT+vaniYsWp4jyroliVG1Gc8oOdbYFc=; b=sIDE+L2KG+GbRLUkdK4tBTZdU9aseahNsvmgkOW1VGYqRGTKMKSPJflFAoYBWx8HJJ DwHsjMpwUuS2i5VktFdjdOd9Ed14i/7enOXYd5mANtVoWu63V+129EU5INdjk7VqclE6 6Nt0V6utn3kWhW7+tTHpdUCMZE5lR6H//ACBrdtAqKkuzNFkUVeMMfb44ixYsKGyQnpL 2zmrmyARHH55WE7gcUWoIqbUydjFzCDoBEn32NPgezZRimzY3PIIYKjsL1o72PV3ALxs xsmxppPKFVL8hyDX6jhggXb8Gfj+0l7TqaCsnor5kXtsf9x7EXi/rSrh+eegShyXCpyb gorQ== X-Gm-Message-State: AOAM530D682k9bm18uAMxSzvXuEsaxmH86qDzwPtZFpe4mUZ7MObcKHG pt+yYpKiQhBVfXEVTj7StSdmDiCYUOsIP81GBSjeVQ== X-Received: by 2002:a19:435b:: with SMTP id m27mr825249lfj.40.1593148407135; Thu, 25 Jun 2020 22:13:27 -0700 (PDT) MIME-Version: 1.0 References: <20200604175851.758-1-maxim.uvarov@linaro.org> <20200604175851.758-2-maxim.uvarov@linaro.org> <1592507935.15159.5.camel@HansenPartnership.com> <1592578844.4369.5.camel@HansenPartnership.com> <1593012069.28403.11.camel@HansenPartnership.com> <3aa8705a-0342-25ea-00c4-d5370d91ddb4@forissier.org> In-Reply-To: From: Sumit Garg Date: Fri, 26 Jun 2020 10:43:15 +0530 Message-ID: Subject: Re: [Tee-dev] [PATCHv8 1/3] optee: use uuid for sysfs driver entry To: Maxim Uvarov Cc: Jerome Forissier , James Bottomley , Greg Kroah-Hartman , Linux Kernel Mailing List , Jarkko Sakkinen , Arnd Bergmann , "tee-dev @ lists . linaro . org" , Jason Gunthorpe , linux-integrity@vger.kernel.org, peterhuewe@gmx.de Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 25 Jun 2020 at 18:22, Maxim Uvarov wrote: > > On Wed, 24 Jun 2020 at 18:44, Jerome Forissier wrote: > > > > > > > > On 6/24/20 5:21 PM, James Bottomley wrote: > > > On Wed, 2020-06-24 at 16:17 +0530, Sumit Garg wrote: > > >> Apologies for delay in my reply as I was busy with some other stuff. > > >> > > >> On Fri, 19 Jun 2020 at 20:30, James Bottomley > > >> wrote: > > > [...] > > >>> it's about consistency with what the kernel types mean. When some > > >>> checker detects your using little endian operations on a big endian > > >>> structure (like in the prink for instance) they're going to keep > > >>> emailing you about it. > > >> > > >> As mentioned above, using different terminology is meant to cause > > >> more confusion than just difference in endianness which is manageable > > >> inside TEE. > > >> > > >> And I think it's safe to say that the kernel implements UUID in big > > >> endian format and thus uses %pUb whereas OP-TEE implements UUID in > > >> little endian format and thus uses %pUl. > > > > > > So what I think you're saying is that if we still had uuid_be and > > > uuid_le you'd use uuid_le, because that's exactly the structure > > > described in the docs. But because we renamed > > > > > > uuid_be -> uuid_t > > > uuid_le -> guid_t > > > > > > You can't use guid_t as a kernel type because it has the wrong name? > > > > Let me try to clear the confusion that I introduce myself I believe :-/ > > IMO: > > > > - optee_register_device(const uuid_t *device_uuid) *is* the correct > > prototype. > > - device_uuid is *guaranteed* to be BE because OP-TEE makes this > > guarantee (it converts from its internal LE representation to BE when > > enumerating the devices, but it doesn't matter to the kernel). > > - Therefore %pUb is the correct format. > > > > I'm sorry for doubting the BE order initially. I am so used to OP-TEE > > using LE internally, that I missed the fact that we have an explicit > > conversion... > > > > Does this sound good? > > > > Thanks, > > -- > > Jerome > > I think your description is correct. But I think this problem would > be solved outside of the current patchset. > All places should use one single format (LE): I guess you missed the point that uuid_t is implemented in BE format in the kernel which is compliant as per RFC 4122. > - internal optee representation; > - device enumeration pta; > - this kernel driver which creates sysfs entry and sets > uid_copy(&optee_device->id.uuid, device_uuid); > - matching function; > - drivers use UUID_INIT(); See carefully the implementation of UUID_INIT() which is in BE format. -Sumit > > In that way everything will be consistent. But it will require > changing other pieces, not just the kernel. While > these patches add functionality to support current device enumeration > in optee os. > So I think this version is ok to be applied. > > Regards, > Maxim.