reg = <0x3 0 0x10000>;
         };
 
-* Freescale BCSR GPIO banks
-
-Some BCSR registers act as simple GPIO controllers, each such
-register can be represented by the gpio-controller node.
-
-Required properities:
-- compatible : Should be "fsl,<board>-bcsr-gpio".
-- reg : Should contain the address and the length of the GPIO bank
-  register.
-- #gpio-cells : Should be two. The first cell is the pin number and the
-  second cell is used to specify optional parameters (currently unused).
-- gpio-controller : Marks the port as GPIO controller.
-
-Example:
-
-       bcsr@1,0 {
-               #address-cells = <1>;
-               #size-cells = <1>;
-               compatible = "fsl,mpc8360mds-bcsr";
-               reg = <1 0 0x8000>;
-               ranges = <0 1 0 0x8000>;
-
-               bcsr13: gpio-controller@d {
-                       #gpio-cells = <2>;
-                       compatible = "fsl,mpc8360mds-bcsr-gpio";
-                       reg = <0xd 1>;
-                       gpio-controller;
-               };
-       };
-
 * Freescale on-board FPGA connected on I2C bus
 
 Some Freescale boards like BSC9132QDS have on board FPGA connected on
 
 CONFIG_PPC_MPC5200_BUGFIX=y
 CONFIG_PPC_MPC5200_LPBFIFO=m
 # CONFIG_PPC_PMAC is not set
-CONFIG_SIMPLE_GPIO=y
 CONFIG_NET=y
 CONFIG_PACKET=y
 CONFIG_UNIX=y
 
 #include <asm/udbg.h>
 #include <sysdev/fsl_soc.h>
 #include <sysdev/fsl_pci.h>
-#include <sysdev/simple_gpio.h>
 #include <soc/fsl/qe/qe.h>
 #include <soc/fsl/qe/qe_ic.h>
 
                qe_usb_clock_set(QE_CLK21, 48000000);
        } else {
                setbits8(&bcsr[13], BCSR13_USBMODE);
-               /*
-                * The BCSR GPIOs are used to control power and
-                * speed of the USB transceiver. This is needed for
-                * the USB Host only.
-                */
-               simple_gpiochip_init("fsl,mpc8360mds-bcsr-gpio");
        }
 
        of_node_put(np);
 
 #include <asm/udbg.h>
 #include <sysdev/fsl_soc.h>
 #include <sysdev/fsl_pci.h>
-#include <sysdev/simple_gpio.h>
 #include <soc/fsl/qe/qe.h>
 #include <soc/fsl/qe/qe_ic.h>
 #include <asm/mpic.h>
 
 static int __init mpc85xx_publish_devices(void)
 {
-       if (machine_is(mpc8568_mds))
-               simple_gpiochip_init("fsl,mpc8568mds-bcsr-gpio");
-       if (machine_is(mpc8569_mds))
-               simple_gpiochip_init("fsl,mpc8569mds-bcsr-gpio");
-
        return mpc85xx_common_publish_devices();
 }
 
 
 #include <linux/of_platform.h>
 #include <sysdev/fsl_pci.h>
 #include <sysdev/fsl_soc.h>
-#include <sysdev/simple_gpio.h>
 
 #include "mpc86xx.h"
 
 
 static int __init mpc8610_declare_of_platform_devices(void)
 {
-       /* Firstly, register PIXIS GPIOs. */
-       simple_gpiochip_init("fsl,fpga-pixis-gpio-bank");
-
        /* Enable wakeup on PIXIS' event IRQ. */
        mpc8610_suspend_init();
 
 
          replacing their get_rtc_time/set_rtc_time callbacks with
          a proper RTC device driver.
 
-config SIMPLE_GPIO
-       bool "Support for simple, memory-mapped GPIO controllers"
-       depends on PPC
-       select GPIOLIB
-       help
-         Say Y here to support simple, memory-mapped GPIO controllers.
-         These are usually BCSRs used to control board's switches, LEDs,
-         chip-selects, Ethernet/USB PHY's power and various other small
-         on-board peripherals.
-
 config MCU_MPC8349EMITX
        bool "MPC8349E-mITX MCU driver"
        depends on I2C=y && PPC_83xx
 
 obj-$(CONFIG_FSL_LBC)          += fsl_lbc.o
 obj-$(CONFIG_FSL_GTM)          += fsl_gtm.o
 obj-$(CONFIG_FSL_85XX_CACHE_SRAM)      += fsl_85xx_l2ctlr.o fsl_85xx_cache_sram.o
-obj-$(CONFIG_SIMPLE_GPIO)      += simple_gpio.o
 obj-$(CONFIG_FSL_RIO)          += fsl_rio.o fsl_rmu.o
 obj-$(CONFIG_TSI108_BRIDGE)    += tsi108_pci.o tsi108_dev.o
 obj-$(CONFIG_RTC_DRV_CMOS)     += rtc_cmos_setup.o
 
+++ /dev/null
-// SPDX-License-Identifier: GPL-2.0-or-later
-/*
- * Simple Memory-Mapped GPIOs
- *
- * Copyright (c) MontaVista Software, Inc. 2008.
- *
- * Author: Anton Vorontsov <avorontsov@ru.mvista.com>
- */
-
-#include <linux/init.h>
-#include <linux/kernel.h>
-#include <linux/spinlock.h>
-#include <linux/types.h>
-#include <linux/ioport.h>
-#include <linux/io.h>
-#include <linux/of.h>
-#include <linux/of_gpio.h>
-#include <linux/gpio/driver.h>
-#include <linux/slab.h>
-#include <asm/prom.h>
-#include "simple_gpio.h"
-
-struct u8_gpio_chip {
-       struct of_mm_gpio_chip mm_gc;
-       spinlock_t lock;
-
-       /* shadowed data register to clear/set bits safely */
-       u8 data;
-};
-
-static u8 u8_pin2mask(unsigned int pin)
-{
-       return 1 << (8 - 1 - pin);
-}
-
-static int u8_gpio_get(struct gpio_chip *gc, unsigned int gpio)
-{
-       struct of_mm_gpio_chip *mm_gc = to_of_mm_gpio_chip(gc);
-
-       return !!(in_8(mm_gc->regs) & u8_pin2mask(gpio));
-}
-
-static void u8_gpio_set(struct gpio_chip *gc, unsigned int gpio, int val)
-{
-       struct of_mm_gpio_chip *mm_gc = to_of_mm_gpio_chip(gc);
-       struct u8_gpio_chip *u8_gc = gpiochip_get_data(gc);
-       unsigned long flags;
-
-       spin_lock_irqsave(&u8_gc->lock, flags);
-
-       if (val)
-               u8_gc->data |= u8_pin2mask(gpio);
-       else
-               u8_gc->data &= ~u8_pin2mask(gpio);
-
-       out_8(mm_gc->regs, u8_gc->data);
-
-       spin_unlock_irqrestore(&u8_gc->lock, flags);
-}
-
-static int u8_gpio_dir_in(struct gpio_chip *gc, unsigned int gpio)
-{
-       return 0;
-}
-
-static int u8_gpio_dir_out(struct gpio_chip *gc, unsigned int gpio, int val)
-{
-       u8_gpio_set(gc, gpio, val);
-       return 0;
-}
-
-static void u8_gpio_save_regs(struct of_mm_gpio_chip *mm_gc)
-{
-       struct u8_gpio_chip *u8_gc =
-               container_of(mm_gc, struct u8_gpio_chip, mm_gc);
-
-       u8_gc->data = in_8(mm_gc->regs);
-}
-
-static int __init u8_simple_gpiochip_add(struct device_node *np)
-{
-       int ret;
-       struct u8_gpio_chip *u8_gc;
-       struct of_mm_gpio_chip *mm_gc;
-       struct gpio_chip *gc;
-
-       u8_gc = kzalloc(sizeof(*u8_gc), GFP_KERNEL);
-       if (!u8_gc)
-               return -ENOMEM;
-
-       spin_lock_init(&u8_gc->lock);
-
-       mm_gc = &u8_gc->mm_gc;
-       gc = &mm_gc->gc;
-
-       mm_gc->save_regs = u8_gpio_save_regs;
-       gc->ngpio = 8;
-       gc->direction_input = u8_gpio_dir_in;
-       gc->direction_output = u8_gpio_dir_out;
-       gc->get = u8_gpio_get;
-       gc->set = u8_gpio_set;
-
-       ret = of_mm_gpiochip_add_data(np, mm_gc, u8_gc);
-       if (ret)
-               goto err;
-       return 0;
-err:
-       kfree(u8_gc);
-       return ret;
-}
-
-void __init simple_gpiochip_init(const char *compatible)
-{
-       struct device_node *np;
-
-       for_each_compatible_node(np, NULL, compatible) {
-               int ret;
-               struct resource r;
-
-               ret = of_address_to_resource(np, 0, &r);
-               if (ret)
-                       goto err;
-
-               switch (resource_size(&r)) {
-               case 1:
-                       ret = u8_simple_gpiochip_add(np);
-                       if (ret)
-                               goto err;
-                       break;
-               default:
-                       /*
-                        * Whenever you need support for GPIO bank width > 1,
-                        * please just turn u8_ code into huge macros, and
-                        * construct needed uX_ code with it.
-                        */
-                       ret = -ENOSYS;
-                       goto err;
-               }
-               continue;
-err:
-               pr_err("%pOF: registration failed, status %d\n", np, ret);
-       }
-}
 
+++ /dev/null
-/* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __SYSDEV_SIMPLE_GPIO_H
-#define __SYSDEV_SIMPLE_GPIO_H
-
-#include <linux/errno.h>
-
-#ifdef CONFIG_SIMPLE_GPIO
-extern void simple_gpiochip_init(const char *compatible);
-#else
-static inline void simple_gpiochip_init(const char *compatible) {}
-#endif /* CONFIG_SIMPLE_GPIO */
-
-#endif /* __SYSDEV_SIMPLE_GPIO_H */