Received: by 2002:a05:6a10:83d0:0:0:0:0 with SMTP id o16csp54829pxh; Thu, 7 Apr 2022 13:48:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyc2ctTmVP6iz7nAqXNkVebmS9owt3z9JXoNsBcPNiz9jJ2m7BMX1Vr7P9krFDjuL4BGdDB X-Received: by 2002:a63:150c:0:b0:39c:c255:27c1 with SMTP id v12-20020a63150c000000b0039cc25527c1mr5083552pgl.293.1649364479979; Thu, 07 Apr 2022 13:47:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649364479; cv=none; d=google.com; s=arc-20160816; b=P1gH+5syND4bd6DQtlgq1W0QyE680+ojB2pmjBFh0XDcm61/mXbZBLGbmO96EUQEv2 itF3lyWmn3kQayxq5uPftgA63T6v+N2yeRXBSjEKzLckTrBlkru2JmE+2BVkLMT0p9en U9ay0bbCUFAyaZha31beYc+AqZjzQyuYFkigj+xr3Xrdfv1VQeNJhBAhPu/BaXdkHI9c WtQioGaIp359USx0XY1jilIesoh64Fv/wBdBhHDTz3wF4zTL65z1eC0bRcKq2znLSiMD EwDBGaIMlUFgWbVYtNkRz6nFn6VZ/R6YITjUzgU5T7yeIpeuc2cLduaURWIx5pgvAiYu SGvw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=2Vv5wRMLm7eAUwbieA9P9R0i+n/Nx3ujFLOcNigvPcM=; b=HVUhWNv4QhKXV8Wpbz525DxVimhB/5tc//KGGxVOUCv6mALxq3ThgOLKQU2tUV+m3v 37s0n59JXUKiQfpdJzceOdyNnjvPJ6pf19bjU10x0uuTtkeQQB8/G45zOM/z0vm1LnAr FMgkNZrPMsZUl0oM2CiT2v+rykG/kfHVYFFg27KDXhvFvZV6ntODZaCAICowiAZIR9Fs DtCh6srOg1aXP2ge4IQh5tcjnlxrlPEMBnlr9xzAGvQSXLXAADhhiEnGrzyCFrkvUdLV LHSzD3tZxhp+D75UxRNj7Zf5s6m+biltGYaj9CEnEvT/JOxMFB8eZ1E1BuG3DrkaqpQd xz0w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=Nh9bB1KB; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id bc3-20020a170902930300b00153bc4c09b5si652674plb.265.2022.04.07.13.47.35 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Apr 2022 13:47:59 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=Nh9bB1KB; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id D13943DA8E2; Thu, 7 Apr 2022 12:55:08 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344997AbiDGQa6 (ORCPT + 99 others); Thu, 7 Apr 2022 12:30:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58084 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230077AbiDGQaz (ORCPT ); Thu, 7 Apr 2022 12:30:55 -0400 Received: from mail-ej1-x633.google.com (mail-ej1-x633.google.com [IPv6:2a00:1450:4864:20::633]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E34FB2654B for ; Thu, 7 Apr 2022 09:28:54 -0700 (PDT) Received: by mail-ej1-x633.google.com with SMTP id bh17so11959051ejb.8 for ; Thu, 07 Apr 2022 09:28:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=2Vv5wRMLm7eAUwbieA9P9R0i+n/Nx3ujFLOcNigvPcM=; b=Nh9bB1KB4S3CAncBLCOeNhoQBW4BpFg7ZxBEKFPIdrPjYLLIXTykS08+eEDZhFWyZ8 Thpi+P0aSF7sVwTnCRHfToCT9gHhhfKUTdrju+t5E7uyVVjlUwgssiadvrQKU9v4qNGE UGaJC8AOLzUArHajp1eLxKaJ3Si9FAGFRr300FrLTKdRBLX62d7XQVrFh69vwxlKtd2C WxnNkYIZtoWVODJra1ZHi7tF1gH3RYCAfr02mNt988D5DFXmHfcUd4rFetFQle6MGTMj Ci6AYLRrWkvEwU37AQ9XJIDCkWAEFa0AQGz/XDUlpe355EzgRwDt0SJo0W1IsGoPS7Kn a4Qg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=2Vv5wRMLm7eAUwbieA9P9R0i+n/Nx3ujFLOcNigvPcM=; b=5oQ4MKzFFrHtfOEkTTZXOT0fy4IHn8WVyMjWEesJlvnLcp3ZsLMRXj+8gQ/dvimtif ZqHQfDS8PX7MUhKVObE5NFDvbMzghauAP1yw9VWooso/z8uTGtIgzlbukVFvOlPF0ZfA EJtAC/exZDRbTpz8xE97xeM/xJBv2bOi5LB8MdmI+iCCNkSQGU2dkBTdFYGfpIUh8wQf stmxvlIcDmcZi56hAyW95kwPZQGP7t/xKi18zRbsq+tc6TXtGNhXd6CmcJibeslcszPv LA/pQvboHigGRY1+vl8D9XlHD36rwo/0ns+J7T0xj8uetdxkzVp+1a5maFjWsx1r6B69 WAXg== X-Gm-Message-State: AOAM530XMtLXw9gDxXxI6F3UyXtdVi5N/vFJLb1DF8PerPZd5paymZFW UpaJKkh/cw1CVg83VhAbilQ6B5QrnfeiqZOzidEafQ== X-Received: by 2002:a17:906:300f:b0:6e0:b38d:777d with SMTP id 15-20020a170906300f00b006e0b38d777dmr14328595ejz.189.1649348933215; Thu, 07 Apr 2022 09:28:53 -0700 (PDT) MIME-Version: 1.0 References: <20220404041101.6276-1-akihiko.odaki@gmail.com> <033c1ec4-4bee-a689-140c-9694dfee435b@gmail.com> In-Reply-To: <033c1ec4-4bee-a689-140c-9694dfee435b@gmail.com> From: Guenter Roeck Date: Thu, 7 Apr 2022 09:28:41 -0700 Message-ID: Subject: Re: [PATCH] platform/chrome: cros_ec_typec: Check for EC driver To: Akihiko Odaki Cc: Prashant Malani , linux-kernel , chrome-platform@lists.linux.dev, Benson Leung , Guenter Roeck Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-9.5 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE, USER_IN_DEF_DKIM_WL autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Apr 6, 2022 at 6:16 PM Akihiko Odaki wrote: [ ... ] > >>> ec_dev = dev_get_drvdata(&typec->ec->ec->dev); I completely missed the part that this is not on the parent. > >>> + if (!ec_dev) > >>> + return -EPROBE_DEFER; [ ... ] > > 1. The parent exists and dev_get_drvdata(pdev->dev.parent) returns > non-NULL value. However, dev_get_drvdata(&typec->ec->ec->dev) returns > NULL. (Yes, that is confusing.) I'm wondering I am actually surprised that typec->ec->ec is not NULL. Underlying problem (or, one underlying problem) is that it is set in cros_ec_register(): /* Register a platform device for the main EC instance */ ec_dev->ec = platform_device_register_data(ec_dev->dev, "cros-ec-dev", PLATFORM_DEVID_AUTO, &ec_p, sizeof(struct cros_ec_platform)); "cros-ec-dev" is the mfd device which instantiates the character device. On devicetree (arm64) systems, the typec device is registered as child of google,cros-ec-spi and thus should be instantiated only after the spi device has been instantiated. The same should happen on ACPI systems, but I don't know if that is really correct. I don't know what exactly is happening, but apparently typec registration happens in parallel with cros-ec-dev registration, which is delayed because the character device is not loaded. As mentioned, I don't understand why typec->ec->ec is not NULL. Can you check what it points to ? Thanks, Guenter > dev_get_drvdata(pdev->dev.parent) returned NULL in the following crash > log but it would be a problem distinct from what is handled with my patch: > https://lore.kernel.org/lkml/CABXOdTe9u_DW=NZM1-J120Gu1gibDy8SsgHP3bJwwLsE_iuLAQ@mail.gmail.com/ > > 2. My patch returns -EPROBE_DEFER instead of -ENODEV and I confirmed it > will eventually be instantiated. > > Regards, > Akihiko Odaki > > > > > Guenter > > > >> Thanks, > >> > >> [1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/drivers/platform/chrome?id=ffebd90532728086007038986900426544e3df4e >