Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp2680715pxb; Fri, 17 Sep 2021 15:53:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyccjklyI4da3NbrSt8mnbKmEjvq3d42QIgzZtIowpbOWggNo7CdlZI9IY3XYjrvhlWVI41 X-Received: by 2002:a05:6638:2050:: with SMTP id t16mr10556877jaj.101.1631919194679; Fri, 17 Sep 2021 15:53:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631919194; cv=none; d=google.com; s=arc-20160816; b=f+HuH7klta9RKUa85p/Cb3bMoPUb1zE6sbDah7N+QpZojJ5iuyqFLyJb+M5KrQlNif cmyUYPRA6SyN9MbMNjKueABA/gChdok/rkzhrLlEFxzT2mzUs1Jwvn7gjzjWayJIMb2G 9ciSyEDDBuoF9w9H34g2Y97PVL1OrpxWsJqi5wYiQHTYPb6sCHUwMDAScdjvWO0hu1Ps cD+Rzm2IggVnsm0SOLm0enTRv4SK9e182gbRTtd+Rc/wqrDEbBIuYiJBw2GX37BPT3p5 9g8SnCxBeqGKGN/3m4mnYw/IqSp/wobCZaINGv9R8tUKcCWdo+bcxPVLcsw5KD68KxL0 CbEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=xzE/NLJgfwAVxkat0RFh+f6sNWwm03C3DeUhhSSlfLM=; b=Tbd8mk5lL4Nfbk89etSZ3ve3pVvJko+V1npRO9qRQ1+eUN98p/pjib+1IbkKM9u9ig rNPPbM2bWEzFN7ZWJq3RhsLXdFJlSKaSS+Cc975pFWz9qko0G23LBLXx/RRwJRTd7uVx NyCh5FFha0/H9WNY7Rbgzyu+g4OPj4qrxRx5V9lF/3WqJXveEJyWTEmify42ycvYHXkB zqF0WmaZgin8d7MQZ2kghi21RrBY7Be5m28+cmBS4X/o4quigmTNsgPqPJUYo8AikIdH kC/ubjis6/rqZMz9/JVXrmKAWlkn/pEUqwYyUWtlrpD7u+o1x492LU4cv1RAvRPvDvbw BOhg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=fhqMfGZa; 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b5si8232959ile.85.2021.09.17.15.52.50; Fri, 17 Sep 2021 15:53:14 -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=@redhat.com header.s=mimecast20190719 header.b=fhqMfGZa; 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233207AbhIQOrC (ORCPT + 99 others); Fri, 17 Sep 2021 10:47:02 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:41510 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229920AbhIQOpx (ORCPT ); Fri, 17 Sep 2021 10:45:53 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1631889867; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=xzE/NLJgfwAVxkat0RFh+f6sNWwm03C3DeUhhSSlfLM=; b=fhqMfGZambCsXrC0/+U0nzVEFz8r60bezasaLVZuc+pKvVDnRd1bDnFpUYUOuMm1NBhAAX yWH32yS7bwRwaZ92Ks3KndYD+8d0RvhG6iVUgGXVjNr1GlNliyWF1h04Hc5YV/uYqj0Jhy 6YMdP8jd71eKYQiTwf1YS3d9f7JvcsU= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-587-Is39RrGqPm-8BizvYNITvw-1; Fri, 17 Sep 2021 10:44:24 -0400 X-MC-Unique: Is39RrGqPm-8BizvYNITvw-1 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 996F010055B9; Fri, 17 Sep 2021 14:44:21 +0000 (UTC) Received: from piliu.users.ipa.redhat.com (ovpn-8-17.pek2.redhat.com [10.72.8.17]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 7692E5DEB8; Fri, 17 Sep 2021 14:43:56 +0000 (UTC) Date: Fri, 17 Sep 2021 22:43:52 +0800 From: Pingfan Liu To: Petr Mladek Cc: Pingfan Liu , linux-kernel@vger.kernel.org, Sumit Garg , Catalin Marinas , Will Deacon , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Marc Zyngier , Julien Thierry , Kees Cook , Masahiro Yamada , Sami Tolvanen , Andrew Morton , Wang Qing , "Peter Zijlstra (Intel)" , Santosh Sivaraj Subject: Re: [PATCH 3/5] kernel/watchdog: adapt the watchdog_hld interface for async model Message-ID: References: <20210915035103.15586-1-kernelfans@gmail.com> <20210915035103.15586-4-kernelfans@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Sep 16, 2021 at 10:29:04AM +0200, Petr Mladek wrote: > On Wed 2021-09-15 11:51:01, Pingfan Liu wrote: > > When lockup_detector_init()->watchdog_nmi_probe(), PMU may be not ready > > yet. E.g. on arm64, PMU is not ready until > > device_initcall(armv8_pmu_driver_init). And it is deeply integrated > > with the driver model and cpuhp. Hence it is hard to push this > > initialization before smp_init(). > > > > But it is easy to take an opposite approach by enabling watchdog_hld to > > get the capability of PMU async. > > This is another cryptic description. I have probably got it after > looking at the 5th patch (was not Cc :-( > > > The async model is achieved by introducing an extra parameter notifier > > of watchdog_nmi_probe(). > > I would say that the code is horrible and looks too complex. > > What about simply calling watchdog_nmi_probe() and > lockup_detector_setup() once again when watchdog_nmi_probe() > failed in lockup_detector_init()? > It may work. But there is still a way to report the PMU NMI capability to watchdog layer accurately. And the API should be extened somehow. I am thinking something, maybe I can model in another way. > Or do not call lockup_detector_init() at all in > kernel_init_freeable() when PMU is not ready yet. > This may be not a good choice. Since lockup_detector_init() had better be ready as early as possible, especially before drivers. Thanks, Pingfan