Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp5521919rdb; Sat, 16 Sep 2023 23:55:57 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFkfU7Ok7Cb+dNoyMAfmtW+kEOj+YYLeat9e2li+2OKjHil47eDh8+ZkChjziALqWnXHW+F X-Received: by 2002:a05:6808:200e:b0:3a4:f8e:d798 with SMTP id q14-20020a056808200e00b003a40f8ed798mr8290513oiw.36.1694933756777; Sat, 16 Sep 2023 23:55:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1694933756; cv=none; d=google.com; s=arc-20160816; b=kk/RKJFbcsiDQ4UQ9bsvCs9ntAwcOhFTL2CqeEqxQRCXQycRSQYEDDFpemJYhIhruX wHfSNlP0HzUEHG8vouLNmkMFyCKrJKBp4zmkGoU2TsBcUNl4dubug8ZE231kXdOazwqM nDWrVnRFkjjwS/W3Fsz+CgrT61NQuGGMIokvhO1ZKlB65QuA/B80UaZB4hekFJA/TIrl GYmPcwmb+bPw0bBHTmRfz6EcYq7VZGAjXwU0JNQet9wDYdNqrCpciOaBlsywCTDW8hiH 1JVzZbo72MJIjjp39526EequSZRK2f7zjyXxbXYajtJfPL17ykn3g46U0kTTb2q2TnNs ymCQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=1AHxpFI3P+MvoMFkWIfa4SlyWB/13RiI7ttqkNp+T4c=; fh=V2IY9JiXP/LhUMpX66+Nr0N3VSfqLapXj8NIppeg0Gk=; b=ewUM1x4J7uZ7fvNsfVqHjIQtVKlLNuNMww6FBr3Unk8rxtYIj7VBT0Ej0sr8by4U9O XxZrCHJloL3CC5dX4lRiCkklaxwqonrY51N7DD2JV+GedtBDxeI6i7ja9qfcyEyyyQ8o sQot50PcRNBwNYi+OFmsVyox5sn2q0/UUuyS0+FzaPHjdd3cMTIsqGF4+I/6sojwad9N a6PFy7SJntBOTNNTayq1CnItcoOavtG43O9QsKtxg5CxR6TOK4ZIQG4hece53FhAhBzv NHR81N+4Nzyfcrr5qJkRsHVcXq21Bl51zakrPP7vIInBjFpCsrSkd5LeUuZ3jBQRfZY7 ckHQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mev.co.uk header.s=20221208-6x11dpa4 header.b=a3+kNefO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=mev.co.uk Return-Path: Received: from snail.vger.email (snail.vger.email. [2620:137:e000::3:7]) by mx.google.com with ESMTPS id lp1-20020a17090b4a8100b0027652755c21si332830pjb.142.2023.09.16.23.55.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 16 Sep 2023 23:55:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) client-ip=2620:137:e000::3:7; Authentication-Results: mx.google.com; dkim=pass header.i=@mev.co.uk header.s=20221208-6x11dpa4 header.b=a3+kNefO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=mev.co.uk Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id BA2C981E9A52; Wed, 13 Sep 2023 09:43:02 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231463AbjIMQnC (ORCPT + 99 others); Wed, 13 Sep 2023 12:43:02 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50184 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231492AbjIMQmv (ORCPT ); Wed, 13 Sep 2023 12:42:51 -0400 Received: from smtp70.iad3a.emailsrvr.com (smtp70.iad3a.emailsrvr.com [173.203.187.70]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2C1B4212F for ; Wed, 13 Sep 2023 09:40:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=mev.co.uk; s=20221208-6x11dpa4; t=1694623227; bh=RPae74SFyNMNMle2W62auXphRC1MqWIbOcTSVGqhAA4=; h=From:To:Subject:Date:From; b=a3+kNefOJvufxK18wLFBSiG55jPgnM6om3EbjBomNip1Ou/UdINokKOKJlIQ/k7Mv oMfrkyC74AI9XW3m0BQ7PXGhQ+6Yxw3ZKVr9mx3wP9zfZJQ3rGjLkEhVsJ/6g/1xHn Nmxu7ptIzvkFNnHcMytPQNICVbB7FMPmwZPBUGTw= X-Auth-ID: abbotti@mev.co.uk Received: by smtp25.relay.iad3a.emailsrvr.com (Authenticated sender: abbotti-AT-mev.co.uk) with ESMTPSA id 55E4C23049; Wed, 13 Sep 2023 12:40:26 -0400 (EDT) From: Ian Abbott To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , Ian Abbott , H Hartley Sweeten , Arnd Bergmann , Niklas Schnelle Subject: [PATCH v2 00/13] comedi: Re-do HAS_IOPORT dependencies Date: Wed, 13 Sep 2023 17:40:00 +0100 Message-Id: <20230913164013.107520-1-abbotti@mev.co.uk> X-Mailer: git-send-email 2.40.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Classification-ID: bb5231ff-a70f-4c9d-8b55-93f03f91465d-1-1 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Wed, 13 Sep 2023 09:43:02 -0700 (PDT) Commit b5c75b68b7de ("comedi: add HAS_IOPORT dependencies") was reverted because it made it impossible to select configuration options that depend on the COMEDI_8254, COMEDI_DAS08, COMEDI_NI_LABPC, or COMEDI_AMPLC_DIO200 options due to changing 'select' directives to 'depends on' directives and there being no other way to select those codependent configuration options. This patch series conditionally removes port I/O support from various comedi modules so they still be built when a future patch removes the port I/O functions (inb(), outb() and friends) unless the HAS_IOPORT configuration option is selected. The final patch 13 adds HAS_IOPORT dependencies to the configuration options as in the reverted patch, but there are now fewer options that need to depend on HAS_IOPORT, and the 'select' directives have not been replaced with 'depends on' directives. 01) comedi: Correct dependencies for COMEDI_NI_PCIDIO 02) comedi: comedi_8254: Use a call-back function for register access 03) comedi: comedi_8254: Replace comedi_8254_init() and comedi_8254_mm_init() 04) comedi: comedi_8254: Conditionally remove I/O port support 05) comedi: 8255_pci: Conditionally remove devices that use port I/O 06) comedi: comedi_8255: Rework subdevice initialization functions 07) comedi: comedi_8255: Conditionally remove I/O port support 08) comedi: ni_labpc_common: Conditionally remove I/O port support 09) comedi: ni_mio_common: Conditionally use I/O port or MMIO 10) comedi: amplc_dio200_pci: Conditionally remove devices that use port I/O 11) comedi: amplc_dio200_common: Refactor register access functions 12) comedi: amplc_dio200_common: Conditionally remove I/O port support 13) comedi: add HAS_IOPORT dependencies again ============================= v2: 0. Patch titles and numbering is unchanged since v1. 1. Corrects [CONFIG_]HAS_PORTIO to [CONFIG_]HAS_IOPORT in the code for patches 05 and 08, and in the description for patches 05, 06, 08, 10, 11, and 12. 2. Enhances the commit description for patch 08 a bit. ============================= drivers/comedi/Kconfig | 45 +++++- drivers/comedi/drivers.c | 3 +- drivers/comedi/drivers/8255.c | 2 +- drivers/comedi/drivers/8255_pci.c | 15 +- drivers/comedi/drivers/adl_pci9111.c | 8 +- drivers/comedi/drivers/adl_pci9118.c | 8 +- drivers/comedi/drivers/adv_pci1710.c | 8 +- drivers/comedi/drivers/adv_pci_dio.c | 14 +- drivers/comedi/drivers/aio_aio12_8.c | 10 +- drivers/comedi/drivers/amplc_dio200_common.c | 104 +++++++++--- drivers/comedi/drivers/amplc_dio200_pci.c | 12 +- drivers/comedi/drivers/amplc_pc236_common.c | 2 +- drivers/comedi/drivers/amplc_pci224.c | 8 +- drivers/comedi/drivers/amplc_pci230.c | 10 +- drivers/comedi/drivers/cb_das16_cs.c | 8 +- drivers/comedi/drivers/cb_pcidas.c | 23 +-- drivers/comedi/drivers/cb_pcidas64.c | 7 +- drivers/comedi/drivers/cb_pcidda.c | 2 +- drivers/comedi/drivers/cb_pcimdas.c | 12 +- drivers/comedi/drivers/cb_pcimdda.c | 2 +- drivers/comedi/drivers/comedi_8254.c | 234 ++++++++++++++++++--------- drivers/comedi/drivers/comedi_8255.c | 123 +++++++------- drivers/comedi/drivers/daqboard2000.c | 4 +- drivers/comedi/drivers/das08.c | 11 +- drivers/comedi/drivers/das16.c | 10 +- drivers/comedi/drivers/das16m1.c | 22 +-- drivers/comedi/drivers/das1800.c | 8 +- drivers/comedi/drivers/das6402.c | 8 +- drivers/comedi/drivers/das800.c | 8 +- drivers/comedi/drivers/dmm32at.c | 3 +- drivers/comedi/drivers/me4000.c | 6 +- drivers/comedi/drivers/ni_at_a2150.c | 8 +- drivers/comedi/drivers/ni_at_ao.c | 8 +- drivers/comedi/drivers/ni_atmio16d.c | 2 +- drivers/comedi/drivers/ni_daq_dio24.c | 2 +- drivers/comedi/drivers/ni_labpc_common.c | 51 +++--- drivers/comedi/drivers/ni_mio_common.c | 74 ++++++--- drivers/comedi/drivers/pcl711.c | 8 +- drivers/comedi/drivers/pcl724.c | 6 +- drivers/comedi/drivers/pcl812.c | 10 +- drivers/comedi/drivers/pcl816.c | 8 +- drivers/comedi/drivers/pcl818.c | 8 +- drivers/comedi/drivers/pcm3724.c | 2 +- drivers/comedi/drivers/rtd520.c | 6 +- include/linux/comedi/comedi_8254.h | 51 ++++-- include/linux/comedi/comedi_8255.h | 24 ++- 46 files changed, 649 insertions(+), 359 deletions(-)