[PATCH] ARM: tegra: paz00: configure WiFi rfkill switch through device tree
Marc Dietrich
marvin24 at gmx.de
Sat Feb 14 12:43:08 PST 2026
Hi Dmitry,
On Fri, 13 Feb 2026, Dmitry Torokhov wrote:
> As of d64c732dfc9e ("net: rfkill: gpio: add DT support") rfkill-gpio
> device can be instantiated via device tree.
>
> Add the declaration there and drop board-paz00.c file and relevant
> Makefile fragments.
>
> Signed-off-by: Dmitry Torokhov <dmitry.torokhov at gmail.com>
> ---
>
> This is not tested on real hardware, compile tested only...
>
> arch/arm/boot/dts/nvidia/tegra20-paz00.dts | 8 ++++
> arch/arm/mach-tegra/Makefile | 2 -
> arch/arm/mach-tegra/board-paz00.c | 56 ----------------------
> arch/arm/mach-tegra/board.h | 2 -
> arch/arm/mach-tegra/tegra.c | 4 --
> 5 files changed, 8 insertions(+), 64 deletions(-)
>
> diff --git a/arch/arm/boot/dts/nvidia/tegra20-paz00.dts b/arch/arm/boot/dts/nvidia/tegra20-paz00.dts
> index 1408e1e00759..d1093ad569e6 100644
> --- a/arch/arm/boot/dts/nvidia/tegra20-paz00.dts
> +++ b/arch/arm/boot/dts/nvidia/tegra20-paz00.dts
> @@ -706,6 +706,14 @@ vdd_pnl_reg: regulator-3v0 {
> enable-active-high;
> };
>
> + rfkill {
> + compatible = "rfkill-gpio";
> + label = "wifi_rfkill";
> + radio-type = "wlan";
> + reset-gpios = <&gpio TEGRA_GPIO(D, 1) GPIO_ACTIVE_HIGH>;
I guess this can be removed, as it should trigger the LED, which is
already included elsewhere ....
> + shutdown-gpios = <&gpio TEGRA_GPIO(K, 5) GPIO_ACTIVE_HIGH>;
> + };
> +
> sound {
> compatible = "nvidia,tegra-audio-alc5632-paz00",
> "nvidia,tegra-audio-alc5632";
I'll give it a try and report back.
Thanks for the nice cleanup!
Marc
> diff --git a/arch/arm/mach-tegra/Makefile b/arch/arm/mach-tegra/Makefile
> index a2bb55bc0081..9e3abb14fbc1 100644
> --- a/arch/arm/mach-tegra/Makefile
> +++ b/arch/arm/mach-tegra/Makefile
> @@ -15,5 +15,3 @@ obj-$(CONFIG_HOTPLUG_CPU) += hotplug.o
>
> obj-$(CONFIG_ARCH_TEGRA_114_SOC) += pm-tegra30.o
> obj-$(CONFIG_ARCH_TEGRA_124_SOC) += pm-tegra30.o
> -
> -obj-$(CONFIG_ARCH_TEGRA_2x_SOC) += board-paz00.o
> diff --git a/arch/arm/mach-tegra/board-paz00.c b/arch/arm/mach-tegra/board-paz00.c
> deleted file mode 100644
> index 3ec810b6f1a7..000000000000
> --- a/arch/arm/mach-tegra/board-paz00.c
> +++ /dev/null
> @@ -1,56 +0,0 @@
> -// SPDX-License-Identifier: GPL-2.0-only
> -/*
> - * arch/arm/mach-tegra/board-paz00.c
> - *
> - * Copyright (C) 2011 Marc Dietrich <marvin24 at gmx.de>
> - *
> - * Based on board-harmony.c
> - * Copyright (C) 2010 Google, Inc.
> - */
> -
> -#include <linux/err.h>
> -#include <linux/gpio/machine.h>
> -#include <linux/gpio/property.h>
> -#include <linux/platform_device.h>
> -#include <linux/printk.h>
> -#include <linux/property.h>
> -
> -#include "board.h"
> -
> -static const struct software_node tegra_gpiochip_node = {
> - .name = "tegra-gpio",
> -};
> -
> -static const struct property_entry wifi_rfkill_prop[] __initconst = {
> - PROPERTY_ENTRY_STRING("name", "wifi_rfkill"),
> - PROPERTY_ENTRY_STRING("type", "wlan"),
> - PROPERTY_ENTRY_GPIO("reset-gpios",
> - &tegra_gpiochip_node, 25, GPIO_ACTIVE_HIGH),
> - PROPERTY_ENTRY_GPIO("shutdown-gpios",
> - &tegra_gpiochip_node, 85, GPIO_ACTIVE_HIGH),
> - { }
> -};
> -
> -static const struct platform_device_info wifi_rfkill_info __initconst = {
> - .name = "rfkill_gpio",
> - .id = PLATFORM_DEVID_NONE,
> - .properties = wifi_rfkill_prop,
> -};
> -
> -void __init tegra_paz00_wifikill_init(void)
> -{
> - struct platform_device *pd;
> - int err;
> -
> - err = software_node_register(&tegra_gpiochip_node);
> - if (err) {
> - pr_err("failed to register %s node: %d\n",
> - tegra_gpiochip_node.name, err);
> - return;
> - }
> -
> - pd = platform_device_register_full(&wifi_rfkill_info);
> - err = PTR_ERR_OR_ZERO(pd);
> - if (err)
> - pr_err("failed to register WiFi rfkill device: %d\n", err);
> -}
> diff --git a/arch/arm/mach-tegra/board.h b/arch/arm/mach-tegra/board.h
> index 7b3ef0dc9be1..86c3ea0d6b30 100644
> --- a/arch/arm/mach-tegra/board.h
> +++ b/arch/arm/mach-tegra/board.h
> @@ -19,6 +19,4 @@
> void __init tegra_map_common_io(void);
> void __init tegra_init_irq(void);
>
> -void __init tegra_paz00_wifikill_init(void);
> -
> #endif
> diff --git a/arch/arm/mach-tegra/tegra.c b/arch/arm/mach-tegra/tegra.c
> index 9ef1dfa7b926..f324a7e491d8 100644
> --- a/arch/arm/mach-tegra/tegra.c
> +++ b/arch/arm/mach-tegra/tegra.c
> @@ -83,10 +83,6 @@ static void __init tegra_dt_init(void)
>
> static void __init tegra_dt_init_late(void)
> {
> - if (IS_ENABLED(CONFIG_ARCH_TEGRA_2x_SOC) &&
> - of_machine_is_compatible("compal,paz00"))
> - tegra_paz00_wifikill_init();
> -
> if (IS_ENABLED(CONFIG_ARCH_TEGRA_2x_SOC) &&
> of_machine_is_compatible("nvidia,tegra20"))
> platform_device_register_simple("tegra20-cpufreq", -1, NULL, 0);
> --
> 2.53.0.310.g728cabbaf7-goog
>
>
> --
> Dmitry
>
>
More information about the linux-arm-kernel
mailing list