OpenSBI Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Anup Patel <apatel@ventanamicro.com>
To: opensbi@lists.infradead.org
Subject: [PATCH v7 11/17] lib: utils/gpio: Use kconfig for enabling/disabling drivers
Date: Thu,  4 Aug 2022 20:01:00 +0530	[thread overview]
Message-ID: <20220804143106.64599-12-apatel@ventanamicro.com> (raw)
In-Reply-To: <20220804143106.64599-1-apatel@ventanamicro.com>

We update gpio drivers makefile to use kconfig for enabling/disabling
drivers. To avoid compile errors, we also enable appropriate gpio
drivers for each platform.

Signed-off-by: Anup Patel <apatel@ventanamicro.com>
Tested-by: Andrew Jones <ajones@ventanamicro.com>
---
 lib/utils/Kconfig                  |  2 ++
 lib/utils/gpio/Kconfig             | 22 ++++++++++++++++++++++
 lib/utils/gpio/objects.mk          | 10 +++++-----
 lib/utils/reset/Kconfig            |  1 +
 platform/generic/configs/defconfig |  2 ++
 5 files changed, 32 insertions(+), 5 deletions(-)
 create mode 100644 lib/utils/gpio/Kconfig

diff --git a/lib/utils/Kconfig b/lib/utils/Kconfig
index 39452d5..673b02b 100644
--- a/lib/utils/Kconfig
+++ b/lib/utils/Kconfig
@@ -2,6 +2,8 @@
 
 menu "Utils and Drivers Support"
 
+source "$(OPENSBI_SRC_DIR)/lib/utils/gpio/Kconfig"
+
 source "$(OPENSBI_SRC_DIR)/lib/utils/i2c/Kconfig"
 
 source "$(OPENSBI_SRC_DIR)/lib/utils/ipi/Kconfig"
diff --git a/lib/utils/gpio/Kconfig b/lib/utils/gpio/Kconfig
new file mode 100644
index 0000000..daf7f91
--- /dev/null
+++ b/lib/utils/gpio/Kconfig
@@ -0,0 +1,22 @@
+# SPDX-License-Identifier: BSD-2-Clause
+
+menu "GPIO Support"
+
+config FDT_GPIO
+	bool "FDT based GPIO drivers"
+	select GPIO
+	default n
+
+if FDT_GPIO
+
+config FDT_GPIO_SIFIVE
+	bool "SiFive GPIO FDT driver"
+	default n
+
+endif
+
+config GPIO
+	bool "GPIO support"
+	default n
+
+endmenu
diff --git a/lib/utils/gpio/objects.mk b/lib/utils/gpio/objects.mk
index a5e131b..eedd699 100644
--- a/lib/utils/gpio/objects.mk
+++ b/lib/utils/gpio/objects.mk
@@ -7,10 +7,10 @@
 #   Anup Patel <anup.patel@wdc.com>
 #
 
-libsbiutils-objs-y += gpio/fdt_gpio.o
-libsbiutils-objs-y += gpio/fdt_gpio_drivers.o
+libsbiutils-objs-$(CONFIG_FDT_GPIO) += gpio/fdt_gpio.o
+libsbiutils-objs-$(CONFIG_FDT_GPIO) += gpio/fdt_gpio_drivers.o
 
-carray-fdt_gpio_drivers-y += fdt_gpio_sifive
-libsbiutils-objs-y += gpio/fdt_gpio_sifive.o
+carray-fdt_gpio_drivers-$(CONFIG_FDT_GPIO_SIFIVE) += fdt_gpio_sifive
+libsbiutils-objs-$(CONFIG_FDT_GPIO_SIFIVE) += gpio/fdt_gpio_sifive.o
 
-libsbiutils-objs-y += gpio/gpio.o
+libsbiutils-objs-$(CONFIG_GPIO) += gpio/gpio.o
diff --git a/lib/utils/reset/Kconfig b/lib/utils/reset/Kconfig
index e7a71e3..71996cb 100644
--- a/lib/utils/reset/Kconfig
+++ b/lib/utils/reset/Kconfig
@@ -10,6 +10,7 @@ if FDT_RESET
 
 config FDT_RESET_GPIO
 	bool "GPIO FDT reset driver"
+	depends on FDT_GPIO
 	default n
 
 config FDT_RESET_HTIF
diff --git a/platform/generic/configs/defconfig b/platform/generic/configs/defconfig
index c9c221e..d56cef2 100644
--- a/platform/generic/configs/defconfig
+++ b/platform/generic/configs/defconfig
@@ -1,3 +1,5 @@
+CONFIG_FDT_GPIO=y
+CONFIG_FDT_GPIO_SIFIVE=y
 CONFIG_FDT_I2C=y
 CONFIG_FDT_I2C_SIFIVE=y
 CONFIG_FDT_IPI=y
-- 
2.34.1



  parent reply	other threads:[~2022-08-04 14:31 UTC|newest]

Thread overview: 24+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-08-04 14:30 [PATCH v7 00/17] OpenSBI Kconfig Support Anup Patel
2022-08-04 14:30 ` [PATCH v7 01/17] scripts: Add Kconfiglib v14.1.0 under scripts directory Anup Patel
2022-08-04 14:30 ` [PATCH v7 02/17] Makefile: Add initial kconfig support for each platform Anup Patel
2022-08-04 14:30 ` [PATCH v7 03/17] Makefile: Compile lib/utils sources separately " Anup Patel
2022-08-04 14:30 ` [PATCH v7 04/17] lib: utils/serial: Use kconfig for enabling/disabling drivers Anup Patel
2022-08-04 14:30 ` [PATCH v7 05/17] lib: utils/reset: " Anup Patel
2022-08-04 14:30 ` [PATCH v7 06/17] lib: utils/sys: " Anup Patel
2022-08-04 14:30 ` [PATCH v7 07/17] lib: utils/timer: " Anup Patel
2022-08-04 14:30 ` [PATCH v7 08/17] lib: utils/ipi: " Anup Patel
2022-08-04 14:30 ` [PATCH v7 09/17] lib: utils/irqchip: " Anup Patel
2022-08-04 14:30 ` [PATCH v7 10/17] lib: utils/i2c: " Anup Patel
2022-08-04 14:31 ` Anup Patel [this message]
2022-08-04 14:31 ` [PATCH v7 12/17] lib: utils/fdt: Use kconfig for enabling/disabling Anup Patel
2022-08-04 14:31 ` [PATCH v7 13/17] platform: generic: Use kconfig for enabling/disabling overrides Anup Patel
2022-08-04 14:31 ` [PATCH v7 14/17] platform: generic: Use kconfig to set platform version and default name Anup Patel
2022-08-04 14:31 ` [PATCH v7 15/17] platform: Remove redundant config.mk from all platforms Anup Patel
2022-08-04 14:31 ` [PATCH v7 16/17] docs: Update documentation for kconfig support Anup Patel
2022-08-04 15:15   ` Andrew Jones
2022-08-04 14:31 ` [PATCH v7 17/17] Makefile: Fix typo related to object.mk Anup Patel
2022-08-04 15:16   ` Andrew Jones
2022-08-05  6:22 ` [PATCH v7 00/17] OpenSBI Kconfig Support Andrew Jones
2022-08-05 20:47 ` Atish Patra
2022-08-05 21:09   ` Atish Patra
2022-08-08  3:42     ` Anup Patel

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20220804143106.64599-12-apatel@ventanamicro.com \
    --to=apatel@ventanamicro.com \
    --cc=opensbi@lists.infradead.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox