Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp432062ybl; Fri, 23 Aug 2019 03:07:17 -0700 (PDT) X-Google-Smtp-Source: APXvYqyTkMWvGw5Q759A8NOTxcP8SnhW86A3O9quR32s0V5etxYh1IfsNF+PrH8fnu9m65UvTugb X-Received: by 2002:a17:90a:9f4a:: with SMTP id q10mr4329267pjv.95.1566554836829; Fri, 23 Aug 2019 03:07:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566554836; cv=none; d=google.com; s=arc-20160816; b=HbFabk1s2KG7PkiBOIWIoxWfiA54fSsVhKeQS3zGkQO0I6cxDxc4c2gvEV4hpd+k3W uzYg6HulIoPk7GwNHkwxQ438sBPl+LufkBbyhuicBHIU/Y4UdWQF/ZUCIM9geF6cunxh Is/x9XQ9nA9YkX2yGNyUOmGtSgTV/kXznBTu44wnZE/cr/iCujY1+Rawa+lVxeW0JGTT PCwo+Hp7ZXNGBloXhfeSVmYfh5iJJ14G4BPkUUPR0M7NCaAytiBOEmjjJqtPKFTgT1Ax hSFPS8vlqwHnDvIaiZB0UqEYlqephwHBP287OEyYi9eS+1rt/mKXHfuF1JQ69SQmFMUI UIcw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=6tbH7ms3h4uM5U9Ws6DAqfHnohIIVbIkwpqBSedRmlM=; b=X+jvLGH5PBRE4hKkgg+41+sIrvREHnG1nVldCAEPEP5464GmAMyz2r5P+Of0/qshSl f6iK6s2/K+VddGW9oYWIeiZ0BOBK1DAeUiSCa5NmkHoQQqGYxrlXwEAm7piIWebEfEY1 HVyUs0somKeUhh19n/wfSQNhOKb5y83kl4TxEo4pqJvWiGkyxq4PtPSP6BKs0bsSVL2O tjDbW6Eyv91ihTNlsb+lvhqpPN4Qs78cLeNN2CvbgNv4ZDHxxzRV+E4jidXbWypbCByq OC+FtmfJ19wMLzJ8TXTpJWJ+XjVLJk1FbDFe2Ruy2o1B4TayUgk/5n8M2DDBGZOvYkei 2/JQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@endlessm-com.20150623.gappssmtp.com header.s=20150623 header.b=d0p3cB9w; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g1si1964048plj.194.2019.08.23.03.07.00; Fri, 23 Aug 2019 03:07:16 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@endlessm-com.20150623.gappssmtp.com header.s=20150623 header.b=d0p3cB9w; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404608AbfHWGhe (ORCPT + 99 others); Fri, 23 Aug 2019 02:37:34 -0400 Received: from mail-pg1-f193.google.com ([209.85.215.193]:37368 "EHLO mail-pg1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2404002AbfHWGhe (ORCPT ); Fri, 23 Aug 2019 02:37:34 -0400 Received: by mail-pg1-f193.google.com with SMTP id d1so5214814pgp.4 for ; Thu, 22 Aug 2019 23:37:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=endlessm-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=6tbH7ms3h4uM5U9Ws6DAqfHnohIIVbIkwpqBSedRmlM=; b=d0p3cB9w0XEvZNGh/sT2OplEKsIxAB3wVwUy9GQCSdE9+kmR4zjvRI6sUCjM9qNq6+ kqFN87bnXgu0pqReGQwC1LnjpFejNbSxg8F/4Ct9SoPPct6cEKjsKiQwD12QxpMRIuo/ zy9f9W3YFNthLQv+zl6Em4HM5mhAb+YH8qmoQolhR8LwfWGhHnW+prF4XEmX9gxC3L4Y yqrVY04g/3kVdbIZyVdqdFYF0qyt12ap7lncAljl6/4VQgfGvH7AQV+htU/ZJdCGpfz0 hC0AAQkvGHv6tKE/KjfY+QKApQ2XLbOpI93/sO4AdZiJ5P5/HWIoajH6fQxUOCH53PyO WziQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=6tbH7ms3h4uM5U9Ws6DAqfHnohIIVbIkwpqBSedRmlM=; b=LvCVZZljYDvhmAcIU/7Gt1hXqG6dSZCfFtsQOPdSfxGkDKvaCMKeUBaRpH8BMWjKfg 53VZ9ozLam36eos+SqMYqKbPgKtgr+dW8RSXmKVd6sZ2meOaSztgMi3Y+TkHwtIwJTup sPUg2iWhWGTCihJxqaZpVDl9E6zJOJM2NA/GKYEUsqZD9CcBZzskiyK9MzrImr3feuV1 ySt+UBtWo/gG6INnssElmg7FcjU4cMj+n1QxOCw+ymRY1JRqq5hesUAHqz+jVbrwcmJg 6PfIr5prtHDbpW7UPsLmVoK2OM4x8NnJV11jZZUuVy1zvpVPGGliD5/bDIoy64CdwANb lTMg== X-Gm-Message-State: APjAAAU1Rl8ZwlX3CvUdWrVTyviDfRDYPv9wwGTGV1DAgHPrnZboNRCn 9UyrsoFwh/vqcK6XDVZ0OGYrEg== X-Received: by 2002:a62:3744:: with SMTP id e65mr3502237pfa.69.1566542253388; Thu, 22 Aug 2019 23:37:33 -0700 (PDT) Received: from limbo.local (123-204-46-122.static.seed.net.tw. [123.204.46.122]) by smtp.gmail.com with ESMTPSA id g19sm1552016pfh.27.2019.08.22.23.37.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 22 Aug 2019 23:37:32 -0700 (PDT) From: Daniel Drake To: yhchuang@realtek.com Cc: briannorris@chromium.org, gojun077@gmail.com, jano.vesely@gmail.com, kvalo@codeaurora.org, linux-wireless@vger.kernel.org, linux@endlessm.com Subject: Re: [PATCH v2] rtw88: pci: enable MSI interrupt Date: Fri, 23 Aug 2019 14:37:28 +0800 Message-Id: <20190823063728.14117-1-drake@endlessm.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <1565166487-22048-1-git-send-email-yhchuang@realtek.com> References: <1565166487-22048-1-git-send-email-yhchuang@realtek.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org > + rtw_pci_disable_interrupt(rtwdev, rtwpci); I checked the discussion on the v1 patch thread but I still don't follow this. You're worried about the case where we're inside the interrupt handler and: 1. We read the interrupt status to note what needs to be done 2. 3. We clear the interrupt status bits 4. We proceed to handle the interrupt but missing any work requested by the interrupt in step 2. Is that right? I'm not an expert here, but I don't think this is something that drivers have to worry about. Surely the interrupt controller can be expected to have a mechanism to "queue up" any interrupt that arrives while an interrupt is being handled? Otherwise handling of all types of edge-triggered interrupts (not just MSI) would be overly painful across the board. See e.g. https://patchwork.kernel.org/patch/3333681/ as a reference for what correct interrupt controller behaviour should look like. > + ret = pci_enable_msi(pdev); pci_enable_msi() is "deprecated, don't use" Thanks Daniel