1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042 |
- From badf28957b6dc400dff27bd23ba2ae75d9514be5 Mon Sep 17 00:00:00 2001
- From: John Crispin <john@phrozen.org>
- Date: Sat, 23 Jun 2018 15:04:09 +0200
- Subject: [PATCH 28/33] MIPS: ath79: drop machfiles
- With the target now being fully OF based, we can drop the legacy mach
- files. Boards can now boot fully of devicetree files.
- Signed-off-by: John Crispin <john@phrozen.org>
- ---
- arch/mips/Kconfig | 1 -
- arch/mips/ath79/Kconfig | 73 -------------------
- arch/mips/ath79/Makefile | 10 ---
- arch/mips/ath79/clock.c | 1 -
- arch/mips/ath79/mach-ap121.c | 92 ------------------------
- arch/mips/ath79/mach-ap136.c | 156 -----------------------------------------
- arch/mips/ath79/mach-ap81.c | 100 --------------------------
- arch/mips/ath79/mach-db120.c | 136 -----------------------------------
- arch/mips/ath79/mach-pb44.c | 128 ---------------------------------
- arch/mips/ath79/mach-ubnt-xm.c | 126 ---------------------------------
- arch/mips/ath79/machtypes.h | 28 --------
- arch/mips/ath79/setup.c | 77 +++-----------------
- 12 files changed, 9 insertions(+), 919 deletions(-)
- delete mode 100644 arch/mips/ath79/mach-ap121.c
- delete mode 100644 arch/mips/ath79/mach-ap136.c
- delete mode 100644 arch/mips/ath79/mach-ap81.c
- delete mode 100644 arch/mips/ath79/mach-db120.c
- delete mode 100644 arch/mips/ath79/mach-pb44.c
- delete mode 100644 arch/mips/ath79/mach-ubnt-xm.c
- delete mode 100644 arch/mips/ath79/machtypes.h
- --- a/arch/mips/Kconfig
- +++ b/arch/mips/Kconfig
- @@ -198,7 +198,6 @@ config ATH79
- select COMMON_CLK
- select CLKDEV_LOOKUP
- select IRQ_MIPS_CPU
- - select MIPS_MACHINE
- select SYS_HAS_CPU_MIPS32_R2
- select SYS_HAS_EARLY_PRINTK
- select SYS_SUPPORTS_32BIT_KERNEL
- --- a/arch/mips/ath79/Kconfig
- +++ b/arch/mips/ath79/Kconfig
- @@ -1,79 +1,6 @@
- # SPDX-License-Identifier: GPL-2.0
- if ATH79
-
- -menu "Atheros AR71XX/AR724X/AR913X machine selection"
- -
- -config ATH79_MACH_AP121
- - bool "Atheros AP121 reference board"
- - select SOC_AR933X
- - select ATH79_DEV_GPIO_BUTTONS
- - select ATH79_DEV_LEDS_GPIO
- - select ATH79_DEV_SPI
- - select ATH79_DEV_USB
- - select ATH79_DEV_WMAC
- - help
- - Say 'Y' here if you want your kernel to support the
- - Atheros AP121 reference board.
- -
- -config ATH79_MACH_AP136
- - bool "Atheros AP136 reference board"
- - select SOC_QCA955X
- - select ATH79_DEV_GPIO_BUTTONS
- - select ATH79_DEV_LEDS_GPIO
- - select ATH79_DEV_SPI
- - select ATH79_DEV_USB
- - select ATH79_DEV_WMAC
- - help
- - Say 'Y' here if you want your kernel to support the
- - Atheros AP136 reference board.
- -
- -config ATH79_MACH_AP81
- - bool "Atheros AP81 reference board"
- - select SOC_AR913X
- - select ATH79_DEV_GPIO_BUTTONS
- - select ATH79_DEV_LEDS_GPIO
- - select ATH79_DEV_SPI
- - select ATH79_DEV_USB
- - select ATH79_DEV_WMAC
- - help
- - Say 'Y' here if you want your kernel to support the
- - Atheros AP81 reference board.
- -
- -config ATH79_MACH_DB120
- - bool "Atheros DB120 reference board"
- - select SOC_AR934X
- - select ATH79_DEV_GPIO_BUTTONS
- - select ATH79_DEV_LEDS_GPIO
- - select ATH79_DEV_SPI
- - select ATH79_DEV_USB
- - select ATH79_DEV_WMAC
- - help
- - Say 'Y' here if you want your kernel to support the
- - Atheros DB120 reference board.
- -
- -config ATH79_MACH_PB44
- - bool "Atheros PB44 reference board"
- - select SOC_AR71XX
- - select ATH79_DEV_GPIO_BUTTONS
- - select ATH79_DEV_LEDS_GPIO
- - select ATH79_DEV_SPI
- - select ATH79_DEV_USB
- - help
- - Say 'Y' here if you want your kernel to support the
- - Atheros PB44 reference board.
- -
- -config ATH79_MACH_UBNT_XM
- - bool "Ubiquiti Networks XM (rev 1.0) board"
- - select SOC_AR724X
- - select ATH79_DEV_GPIO_BUTTONS
- - select ATH79_DEV_LEDS_GPIO
- - select ATH79_DEV_SPI
- - help
- - Say 'Y' here if you want your kernel to support the
- - Ubiquiti Networks XM (rev 1.0) board.
- -
- -endmenu
- -
- config SOC_AR71XX
- select HW_HAS_PCI
- def_bool n
- --- a/arch/mips/ath79/Makefile
- +++ b/arch/mips/ath79/Makefile
- @@ -22,13 +22,3 @@ obj-$(CONFIG_ATH79_DEV_LEDS_GPIO) += dev
- obj-$(CONFIG_ATH79_DEV_SPI) += dev-spi.o
- obj-$(CONFIG_ATH79_DEV_USB) += dev-usb.o
- obj-$(CONFIG_ATH79_DEV_WMAC) += dev-wmac.o
- -
- -#
- -# Machines
- -#
- -obj-$(CONFIG_ATH79_MACH_AP121) += mach-ap121.o
- -obj-$(CONFIG_ATH79_MACH_AP136) += mach-ap136.o
- -obj-$(CONFIG_ATH79_MACH_AP81) += mach-ap81.o
- -obj-$(CONFIG_ATH79_MACH_DB120) += mach-db120.o
- -obj-$(CONFIG_ATH79_MACH_PB44) += mach-pb44.o
- -obj-$(CONFIG_ATH79_MACH_UBNT_XM) += mach-ubnt-xm.o
- --- a/arch/mips/ath79/clock.c
- +++ b/arch/mips/ath79/clock.c
- @@ -26,7 +26,6 @@
- #include <asm/mach-ath79/ath79.h>
- #include <asm/mach-ath79/ar71xx_regs.h>
- #include "common.h"
- -#include "machtypes.h"
-
- #define AR71XX_BASE_FREQ 40000000
- #define AR724X_BASE_FREQ 40000000
- --- a/arch/mips/ath79/mach-ap121.c
- +++ /dev/null
- @@ -1,92 +0,0 @@
- -/*
- - * Atheros AP121 board support
- - *
- - * Copyright (C) 2011 Gabor Juhos <juhosg@openwrt.org>
- - *
- - * This program is free software; you can redistribute it and/or modify it
- - * under the terms of the GNU General Public License version 2 as published
- - * by the Free Software Foundation.
- - */
- -
- -#include "machtypes.h"
- -#include "dev-gpio-buttons.h"
- -#include "dev-leds-gpio.h"
- -#include "dev-spi.h"
- -#include "dev-usb.h"
- -#include "dev-wmac.h"
- -
- -#define AP121_GPIO_LED_WLAN 0
- -#define AP121_GPIO_LED_USB 1
- -
- -#define AP121_GPIO_BTN_JUMPSTART 11
- -#define AP121_GPIO_BTN_RESET 12
- -
- -#define AP121_KEYS_POLL_INTERVAL 20 /* msecs */
- -#define AP121_KEYS_DEBOUNCE_INTERVAL (3 * AP121_KEYS_POLL_INTERVAL)
- -
- -#define AP121_CAL_DATA_ADDR 0x1fff1000
- -
- -static struct gpio_led ap121_leds_gpio[] __initdata = {
- - {
- - .name = "ap121:green:usb",
- - .gpio = AP121_GPIO_LED_USB,
- - .active_low = 0,
- - },
- - {
- - .name = "ap121:green:wlan",
- - .gpio = AP121_GPIO_LED_WLAN,
- - .active_low = 0,
- - },
- -};
- -
- -static struct gpio_keys_button ap121_gpio_keys[] __initdata = {
- - {
- - .desc = "jumpstart button",
- - .type = EV_KEY,
- - .code = KEY_WPS_BUTTON,
- - .debounce_interval = AP121_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = AP121_GPIO_BTN_JUMPSTART,
- - .active_low = 1,
- - },
- - {
- - .desc = "reset button",
- - .type = EV_KEY,
- - .code = KEY_RESTART,
- - .debounce_interval = AP121_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = AP121_GPIO_BTN_RESET,
- - .active_low = 1,
- - }
- -};
- -
- -static struct spi_board_info ap121_spi_info[] = {
- - {
- - .bus_num = 0,
- - .chip_select = 0,
- - .max_speed_hz = 25000000,
- - .modalias = "mx25l1606e",
- - }
- -};
- -
- -static struct ath79_spi_platform_data ap121_spi_data = {
- - .bus_num = 0,
- - .num_chipselect = 1,
- -};
- -
- -static void __init ap121_setup(void)
- -{
- - u8 *cal_data = (u8 *) KSEG1ADDR(AP121_CAL_DATA_ADDR);
- -
- - ath79_register_leds_gpio(-1, ARRAY_SIZE(ap121_leds_gpio),
- - ap121_leds_gpio);
- - ath79_register_gpio_keys_polled(-1, AP121_KEYS_POLL_INTERVAL,
- - ARRAY_SIZE(ap121_gpio_keys),
- - ap121_gpio_keys);
- -
- - ath79_register_spi(&ap121_spi_data, ap121_spi_info,
- - ARRAY_SIZE(ap121_spi_info));
- - ath79_register_usb();
- - ath79_register_wmac(cal_data);
- -}
- -
- -MIPS_MACHINE(ATH79_MACH_AP121, "AP121", "Atheros AP121 reference board",
- - ap121_setup);
- --- a/arch/mips/ath79/mach-ap136.c
- +++ /dev/null
- @@ -1,156 +0,0 @@
- -/*
- - * Qualcomm Atheros AP136 reference board support
- - *
- - * Copyright (c) 2012 Qualcomm Atheros
- - * Copyright (c) 2012-2013 Gabor Juhos <juhosg@openwrt.org>
- - *
- - * Permission to use, copy, modify, and/or distribute this software for any
- - * purpose with or without fee is hereby granted, provided that the above
- - * copyright notice and this permission notice appear in all copies.
- - *
- - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- - *
- - */
- -
- -#include <linux/pci.h>
- -#include <linux/ath9k_platform.h>
- -
- -#include "machtypes.h"
- -#include "dev-gpio-buttons.h"
- -#include "dev-leds-gpio.h"
- -#include "dev-spi.h"
- -#include "dev-usb.h"
- -#include "dev-wmac.h"
- -#include "pci.h"
- -
- -#define AP136_GPIO_LED_STATUS_RED 14
- -#define AP136_GPIO_LED_STATUS_GREEN 19
- -#define AP136_GPIO_LED_USB 4
- -#define AP136_GPIO_LED_WLAN_2G 13
- -#define AP136_GPIO_LED_WLAN_5G 12
- -#define AP136_GPIO_LED_WPS_RED 15
- -#define AP136_GPIO_LED_WPS_GREEN 20
- -
- -#define AP136_GPIO_BTN_WPS 16
- -#define AP136_GPIO_BTN_RFKILL 21
- -
- -#define AP136_KEYS_POLL_INTERVAL 20 /* msecs */
- -#define AP136_KEYS_DEBOUNCE_INTERVAL (3 * AP136_KEYS_POLL_INTERVAL)
- -
- -#define AP136_WMAC_CALDATA_OFFSET 0x1000
- -#define AP136_PCIE_CALDATA_OFFSET 0x5000
- -
- -static struct gpio_led ap136_leds_gpio[] __initdata = {
- - {
- - .name = "qca:green:status",
- - .gpio = AP136_GPIO_LED_STATUS_GREEN,
- - .active_low = 1,
- - },
- - {
- - .name = "qca:red:status",
- - .gpio = AP136_GPIO_LED_STATUS_RED,
- - .active_low = 1,
- - },
- - {
- - .name = "qca:green:wps",
- - .gpio = AP136_GPIO_LED_WPS_GREEN,
- - .active_low = 1,
- - },
- - {
- - .name = "qca:red:wps",
- - .gpio = AP136_GPIO_LED_WPS_RED,
- - .active_low = 1,
- - },
- - {
- - .name = "qca:red:wlan-2g",
- - .gpio = AP136_GPIO_LED_WLAN_2G,
- - .active_low = 1,
- - },
- - {
- - .name = "qca:red:usb",
- - .gpio = AP136_GPIO_LED_USB,
- - .active_low = 1,
- - }
- -};
- -
- -static struct gpio_keys_button ap136_gpio_keys[] __initdata = {
- - {
- - .desc = "WPS button",
- - .type = EV_KEY,
- - .code = KEY_WPS_BUTTON,
- - .debounce_interval = AP136_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = AP136_GPIO_BTN_WPS,
- - .active_low = 1,
- - },
- - {
- - .desc = "RFKILL button",
- - .type = EV_KEY,
- - .code = KEY_RFKILL,
- - .debounce_interval = AP136_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = AP136_GPIO_BTN_RFKILL,
- - .active_low = 1,
- - },
- -};
- -
- -static struct spi_board_info ap136_spi_info[] = {
- - {
- - .bus_num = 0,
- - .chip_select = 0,
- - .max_speed_hz = 25000000,
- - .modalias = "mx25l6405d",
- - }
- -};
- -
- -static struct ath79_spi_platform_data ap136_spi_data = {
- - .bus_num = 0,
- - .num_chipselect = 1,
- -};
- -
- -#ifdef CONFIG_PCI
- -static struct ath9k_platform_data ap136_ath9k_data;
- -
- -static int ap136_pci_plat_dev_init(struct pci_dev *dev)
- -{
- - if (dev->bus->number == 1 && (PCI_SLOT(dev->devfn)) == 0)
- - dev->dev.platform_data = &ap136_ath9k_data;
- -
- - return 0;
- -}
- -
- -static void __init ap136_pci_init(u8 *eeprom)
- -{
- - memcpy(ap136_ath9k_data.eeprom_data, eeprom,
- - sizeof(ap136_ath9k_data.eeprom_data));
- -
- - ath79_pci_set_plat_dev_init(ap136_pci_plat_dev_init);
- - ath79_register_pci();
- -}
- -#else
- -static inline void ap136_pci_init(u8 *eeprom) {}
- -#endif /* CONFIG_PCI */
- -
- -static void __init ap136_setup(void)
- -{
- - u8 *art = (u8 *) KSEG1ADDR(0x1fff0000);
- -
- - ath79_register_leds_gpio(-1, ARRAY_SIZE(ap136_leds_gpio),
- - ap136_leds_gpio);
- - ath79_register_gpio_keys_polled(-1, AP136_KEYS_POLL_INTERVAL,
- - ARRAY_SIZE(ap136_gpio_keys),
- - ap136_gpio_keys);
- - ath79_register_spi(&ap136_spi_data, ap136_spi_info,
- - ARRAY_SIZE(ap136_spi_info));
- - ath79_register_usb();
- - ath79_register_wmac(art + AP136_WMAC_CALDATA_OFFSET);
- - ap136_pci_init(art + AP136_PCIE_CALDATA_OFFSET);
- -}
- -
- -MIPS_MACHINE(ATH79_MACH_AP136_010, "AP136-010",
- - "Atheros AP136-010 reference board",
- - ap136_setup);
- --- a/arch/mips/ath79/mach-ap81.c
- +++ /dev/null
- @@ -1,100 +0,0 @@
- -/*
- - * Atheros AP81 board support
- - *
- - * Copyright (C) 2009-2010 Gabor Juhos <juhosg@openwrt.org>
- - * Copyright (C) 2009 Imre Kaloz <kaloz@openwrt.org>
- - *
- - * This program is free software; you can redistribute it and/or modify it
- - * under the terms of the GNU General Public License version 2 as published
- - * by the Free Software Foundation.
- - */
- -
- -#include "machtypes.h"
- -#include "dev-wmac.h"
- -#include "dev-gpio-buttons.h"
- -#include "dev-leds-gpio.h"
- -#include "dev-spi.h"
- -#include "dev-usb.h"
- -
- -#define AP81_GPIO_LED_STATUS 1
- -#define AP81_GPIO_LED_AOSS 3
- -#define AP81_GPIO_LED_WLAN 6
- -#define AP81_GPIO_LED_POWER 14
- -
- -#define AP81_GPIO_BTN_SW4 12
- -#define AP81_GPIO_BTN_SW1 21
- -
- -#define AP81_KEYS_POLL_INTERVAL 20 /* msecs */
- -#define AP81_KEYS_DEBOUNCE_INTERVAL (3 * AP81_KEYS_POLL_INTERVAL)
- -
- -#define AP81_CAL_DATA_ADDR 0x1fff1000
- -
- -static struct gpio_led ap81_leds_gpio[] __initdata = {
- - {
- - .name = "ap81:green:status",
- - .gpio = AP81_GPIO_LED_STATUS,
- - .active_low = 1,
- - }, {
- - .name = "ap81:amber:aoss",
- - .gpio = AP81_GPIO_LED_AOSS,
- - .active_low = 1,
- - }, {
- - .name = "ap81:green:wlan",
- - .gpio = AP81_GPIO_LED_WLAN,
- - .active_low = 1,
- - }, {
- - .name = "ap81:green:power",
- - .gpio = AP81_GPIO_LED_POWER,
- - .active_low = 1,
- - }
- -};
- -
- -static struct gpio_keys_button ap81_gpio_keys[] __initdata = {
- - {
- - .desc = "sw1",
- - .type = EV_KEY,
- - .code = BTN_0,
- - .debounce_interval = AP81_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = AP81_GPIO_BTN_SW1,
- - .active_low = 1,
- - } , {
- - .desc = "sw4",
- - .type = EV_KEY,
- - .code = BTN_1,
- - .debounce_interval = AP81_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = AP81_GPIO_BTN_SW4,
- - .active_low = 1,
- - }
- -};
- -
- -static struct spi_board_info ap81_spi_info[] = {
- - {
- - .bus_num = 0,
- - .chip_select = 0,
- - .max_speed_hz = 25000000,
- - .modalias = "m25p64",
- - }
- -};
- -
- -static struct ath79_spi_platform_data ap81_spi_data = {
- - .bus_num = 0,
- - .num_chipselect = 1,
- -};
- -
- -static void __init ap81_setup(void)
- -{
- - u8 *cal_data = (u8 *) KSEG1ADDR(AP81_CAL_DATA_ADDR);
- -
- - ath79_register_leds_gpio(-1, ARRAY_SIZE(ap81_leds_gpio),
- - ap81_leds_gpio);
- - ath79_register_gpio_keys_polled(-1, AP81_KEYS_POLL_INTERVAL,
- - ARRAY_SIZE(ap81_gpio_keys),
- - ap81_gpio_keys);
- - ath79_register_spi(&ap81_spi_data, ap81_spi_info,
- - ARRAY_SIZE(ap81_spi_info));
- - ath79_register_wmac(cal_data);
- - ath79_register_usb();
- -}
- -
- -MIPS_MACHINE(ATH79_MACH_AP81, "AP81", "Atheros AP81 reference board",
- - ap81_setup);
- --- a/arch/mips/ath79/mach-db120.c
- +++ /dev/null
- @@ -1,136 +0,0 @@
- -/*
- - * Atheros DB120 reference board support
- - *
- - * Copyright (c) 2011 Qualcomm Atheros
- - * Copyright (c) 2011 Gabor Juhos <juhosg@openwrt.org>
- - *
- - * Permission to use, copy, modify, and/or distribute this software for any
- - * purpose with or without fee is hereby granted, provided that the above
- - * copyright notice and this permission notice appear in all copies.
- - *
- - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- - *
- - */
- -
- -#include <linux/pci.h>
- -#include <linux/ath9k_platform.h>
- -
- -#include "machtypes.h"
- -#include "dev-gpio-buttons.h"
- -#include "dev-leds-gpio.h"
- -#include "dev-spi.h"
- -#include "dev-usb.h"
- -#include "dev-wmac.h"
- -#include "pci.h"
- -
- -#define DB120_GPIO_LED_WLAN_5G 12
- -#define DB120_GPIO_LED_WLAN_2G 13
- -#define DB120_GPIO_LED_STATUS 14
- -#define DB120_GPIO_LED_WPS 15
- -
- -#define DB120_GPIO_BTN_WPS 16
- -
- -#define DB120_KEYS_POLL_INTERVAL 20 /* msecs */
- -#define DB120_KEYS_DEBOUNCE_INTERVAL (3 * DB120_KEYS_POLL_INTERVAL)
- -
- -#define DB120_WMAC_CALDATA_OFFSET 0x1000
- -#define DB120_PCIE_CALDATA_OFFSET 0x5000
- -
- -static struct gpio_led db120_leds_gpio[] __initdata = {
- - {
- - .name = "db120:green:status",
- - .gpio = DB120_GPIO_LED_STATUS,
- - .active_low = 1,
- - },
- - {
- - .name = "db120:green:wps",
- - .gpio = DB120_GPIO_LED_WPS,
- - .active_low = 1,
- - },
- - {
- - .name = "db120:green:wlan-5g",
- - .gpio = DB120_GPIO_LED_WLAN_5G,
- - .active_low = 1,
- - },
- - {
- - .name = "db120:green:wlan-2g",
- - .gpio = DB120_GPIO_LED_WLAN_2G,
- - .active_low = 1,
- - },
- -};
- -
- -static struct gpio_keys_button db120_gpio_keys[] __initdata = {
- - {
- - .desc = "WPS button",
- - .type = EV_KEY,
- - .code = KEY_WPS_BUTTON,
- - .debounce_interval = DB120_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = DB120_GPIO_BTN_WPS,
- - .active_low = 1,
- - },
- -};
- -
- -static struct spi_board_info db120_spi_info[] = {
- - {
- - .bus_num = 0,
- - .chip_select = 0,
- - .max_speed_hz = 25000000,
- - .modalias = "s25sl064a",
- - }
- -};
- -
- -static struct ath79_spi_platform_data db120_spi_data = {
- - .bus_num = 0,
- - .num_chipselect = 1,
- -};
- -
- -#ifdef CONFIG_PCI
- -static struct ath9k_platform_data db120_ath9k_data;
- -
- -static int db120_pci_plat_dev_init(struct pci_dev *dev)
- -{
- - switch (PCI_SLOT(dev->devfn)) {
- - case 0:
- - dev->dev.platform_data = &db120_ath9k_data;
- - break;
- - }
- -
- - return 0;
- -}
- -
- -static void __init db120_pci_init(u8 *eeprom)
- -{
- - memcpy(db120_ath9k_data.eeprom_data, eeprom,
- - sizeof(db120_ath9k_data.eeprom_data));
- -
- - ath79_pci_set_plat_dev_init(db120_pci_plat_dev_init);
- - ath79_register_pci();
- -}
- -#else
- -static inline void db120_pci_init(u8 *eeprom) {}
- -#endif /* CONFIG_PCI */
- -
- -static void __init db120_setup(void)
- -{
- - u8 *art = (u8 *) KSEG1ADDR(0x1fff0000);
- -
- - ath79_register_leds_gpio(-1, ARRAY_SIZE(db120_leds_gpio),
- - db120_leds_gpio);
- - ath79_register_gpio_keys_polled(-1, DB120_KEYS_POLL_INTERVAL,
- - ARRAY_SIZE(db120_gpio_keys),
- - db120_gpio_keys);
- - ath79_register_spi(&db120_spi_data, db120_spi_info,
- - ARRAY_SIZE(db120_spi_info));
- - ath79_register_usb();
- - ath79_register_wmac(art + DB120_WMAC_CALDATA_OFFSET);
- - db120_pci_init(art + DB120_PCIE_CALDATA_OFFSET);
- -}
- -
- -MIPS_MACHINE(ATH79_MACH_DB120, "DB120", "Atheros DB120 reference board",
- - db120_setup);
- --- a/arch/mips/ath79/mach-pb44.c
- +++ /dev/null
- @@ -1,122 +0,0 @@
- -/*
- - * Atheros PB44 reference board support
- - *
- - * Copyright (C) 2009-2010 Gabor Juhos <juhosg@openwrt.org>
- - *
- - * This program is free software; you can redistribute it and/or modify it
- - * under the terms of the GNU General Public License version 2 as published
- - * by the Free Software Foundation.
- - */
- -
- -#include <linux/init.h>
- -#include <linux/platform_device.h>
- -#include <linux/i2c.h>
- -#include <linux/i2c-gpio.h>
- -#include <linux/platform_data/pcf857x.h>
- -
- -#include "machtypes.h"
- -#include "dev-gpio-buttons.h"
- -#include "dev-leds-gpio.h"
- -#include "dev-spi.h"
- -#include "dev-usb.h"
- -#include "pci.h"
- -
- -#define PB44_GPIO_I2C_SCL 0
- -#define PB44_GPIO_I2C_SDA 1
- -
- -#define PB44_GPIO_EXP_BASE 16
- -#define PB44_GPIO_SW_RESET (PB44_GPIO_EXP_BASE + 6)
- -#define PB44_GPIO_SW_JUMP (PB44_GPIO_EXP_BASE + 8)
- -#define PB44_GPIO_LED_JUMP1 (PB44_GPIO_EXP_BASE + 9)
- -#define PB44_GPIO_LED_JUMP2 (PB44_GPIO_EXP_BASE + 10)
- -
- -#define PB44_KEYS_POLL_INTERVAL 20 /* msecs */
- -#define PB44_KEYS_DEBOUNCE_INTERVAL (3 * PB44_KEYS_POLL_INTERVAL)
- -
- -static struct i2c_gpio_platform_data pb44_i2c_gpio_data = {
- - .sda_pin = PB44_GPIO_I2C_SDA,
- - .scl_pin = PB44_GPIO_I2C_SCL,
- -};
- -
- -static struct platform_device pb44_i2c_gpio_device = {
- - .name = "i2c-gpio",
- - .id = 0,
- - .dev = {
- - .platform_data = &pb44_i2c_gpio_data,
- - }
- -};
- -
- -static struct pcf857x_platform_data pb44_pcf857x_data = {
- - .gpio_base = PB44_GPIO_EXP_BASE,
- -};
- -
- -static struct i2c_board_info pb44_i2c_board_info[] __initdata = {
- - {
- - I2C_BOARD_INFO("pcf8575", 0x20),
- - .platform_data = &pb44_pcf857x_data,
- - },
- -};
- -
- -static struct gpio_led pb44_leds_gpio[] __initdata = {
- - {
- - .name = "pb44:amber:jump1",
- - .gpio = PB44_GPIO_LED_JUMP1,
- - .active_low = 1,
- - }, {
- - .name = "pb44:green:jump2",
- - .gpio = PB44_GPIO_LED_JUMP2,
- - .active_low = 1,
- - },
- -};
- -
- -static struct gpio_keys_button pb44_gpio_keys[] __initdata = {
- - {
- - .desc = "soft_reset",
- - .type = EV_KEY,
- - .code = KEY_RESTART,
- - .debounce_interval = PB44_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = PB44_GPIO_SW_RESET,
- - .active_low = 1,
- - } , {
- - .desc = "jumpstart",
- - .type = EV_KEY,
- - .code = KEY_WPS_BUTTON,
- - .debounce_interval = PB44_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = PB44_GPIO_SW_JUMP,
- - .active_low = 1,
- - }
- -};
- -
- -static struct spi_board_info pb44_spi_info[] = {
- - {
- - .bus_num = 0,
- - .chip_select = 0,
- - .max_speed_hz = 25000000,
- - .modalias = "m25p64",
- - },
- -};
- -
- -static struct ath79_spi_platform_data pb44_spi_data = {
- - .bus_num = 0,
- - .num_chipselect = 1,
- -};
- -
- -static void __init pb44_init(void)
- -{
- - i2c_register_board_info(0, pb44_i2c_board_info,
- - ARRAY_SIZE(pb44_i2c_board_info));
- - platform_device_register(&pb44_i2c_gpio_device);
- -
- - ath79_register_leds_gpio(-1, ARRAY_SIZE(pb44_leds_gpio),
- - pb44_leds_gpio);
- - ath79_register_gpio_keys_polled(-1, PB44_KEYS_POLL_INTERVAL,
- - ARRAY_SIZE(pb44_gpio_keys),
- - pb44_gpio_keys);
- - ath79_register_spi(&pb44_spi_data, pb44_spi_info,
- - ARRAY_SIZE(pb44_spi_info));
- - ath79_register_usb();
- - ath79_register_pci();
- -}
- -
- -MIPS_MACHINE(ATH79_MACH_PB44, "PB44", "Atheros PB44 reference board",
- - pb44_init);
- --- a/arch/mips/ath79/mach-ubnt-xm.c
- +++ /dev/null
- @@ -1,126 +0,0 @@
- -/*
- - * Ubiquiti Networks XM (rev 1.0) board support
- - *
- - * Copyright (C) 2011 René Bolldorf <xsecute@googlemail.com>
- - *
- - * Derived from: mach-pb44.c
- - *
- - * This program is free software; you can redistribute it and/or modify it
- - * under the terms of the GNU General Public License version 2 as published
- - * by the Free Software Foundation.
- - */
- -
- -#include <linux/init.h>
- -#include <linux/pci.h>
- -#include <linux/ath9k_platform.h>
- -
- -#include <asm/mach-ath79/irq.h>
- -
- -#include "machtypes.h"
- -#include "dev-gpio-buttons.h"
- -#include "dev-leds-gpio.h"
- -#include "dev-spi.h"
- -#include "pci.h"
- -
- -#define UBNT_XM_GPIO_LED_L1 0
- -#define UBNT_XM_GPIO_LED_L2 1
- -#define UBNT_XM_GPIO_LED_L3 11
- -#define UBNT_XM_GPIO_LED_L4 7
- -
- -#define UBNT_XM_GPIO_BTN_RESET 12
- -
- -#define UBNT_XM_KEYS_POLL_INTERVAL 20
- -#define UBNT_XM_KEYS_DEBOUNCE_INTERVAL (3 * UBNT_XM_KEYS_POLL_INTERVAL)
- -
- -#define UBNT_XM_EEPROM_ADDR (u8 *) KSEG1ADDR(0x1fff1000)
- -
- -static struct gpio_led ubnt_xm_leds_gpio[] __initdata = {
- - {
- - .name = "ubnt-xm:red:link1",
- - .gpio = UBNT_XM_GPIO_LED_L1,
- - .active_low = 0,
- - }, {
- - .name = "ubnt-xm:orange:link2",
- - .gpio = UBNT_XM_GPIO_LED_L2,
- - .active_low = 0,
- - }, {
- - .name = "ubnt-xm:green:link3",
- - .gpio = UBNT_XM_GPIO_LED_L3,
- - .active_low = 0,
- - }, {
- - .name = "ubnt-xm:green:link4",
- - .gpio = UBNT_XM_GPIO_LED_L4,
- - .active_low = 0,
- - },
- -};
- -
- -static struct gpio_keys_button ubnt_xm_gpio_keys[] __initdata = {
- - {
- - .desc = "reset",
- - .type = EV_KEY,
- - .code = KEY_RESTART,
- - .debounce_interval = UBNT_XM_KEYS_DEBOUNCE_INTERVAL,
- - .gpio = UBNT_XM_GPIO_BTN_RESET,
- - .active_low = 1,
- - }
- -};
- -
- -static struct spi_board_info ubnt_xm_spi_info[] = {
- - {
- - .bus_num = 0,
- - .chip_select = 0,
- - .max_speed_hz = 25000000,
- - .modalias = "mx25l6405d",
- - }
- -};
- -
- -static struct ath79_spi_platform_data ubnt_xm_spi_data = {
- - .bus_num = 0,
- - .num_chipselect = 1,
- -};
- -
- -#ifdef CONFIG_PCI
- -static struct ath9k_platform_data ubnt_xm_eeprom_data;
- -
- -static int ubnt_xm_pci_plat_dev_init(struct pci_dev *dev)
- -{
- - switch (PCI_SLOT(dev->devfn)) {
- - case 0:
- - dev->dev.platform_data = &ubnt_xm_eeprom_data;
- - break;
- - }
- -
- - return 0;
- -}
- -
- -static void __init ubnt_xm_pci_init(void)
- -{
- - memcpy(ubnt_xm_eeprom_data.eeprom_data, UBNT_XM_EEPROM_ADDR,
- - sizeof(ubnt_xm_eeprom_data.eeprom_data));
- -
- - ath79_pci_set_plat_dev_init(ubnt_xm_pci_plat_dev_init);
- - ath79_register_pci();
- -}
- -#else
- -static inline void ubnt_xm_pci_init(void) {}
- -#endif /* CONFIG_PCI */
- -
- -static void __init ubnt_xm_init(void)
- -{
- - ath79_register_leds_gpio(-1, ARRAY_SIZE(ubnt_xm_leds_gpio),
- - ubnt_xm_leds_gpio);
- -
- - ath79_register_gpio_keys_polled(-1, UBNT_XM_KEYS_POLL_INTERVAL,
- - ARRAY_SIZE(ubnt_xm_gpio_keys),
- - ubnt_xm_gpio_keys);
- -
- - ath79_register_spi(&ubnt_xm_spi_data, ubnt_xm_spi_info,
- - ARRAY_SIZE(ubnt_xm_spi_info));
- -
- - ubnt_xm_pci_init();
- -}
- -
- -MIPS_MACHINE(ATH79_MACH_UBNT_XM,
- - "UBNT-XM",
- - "Ubiquiti Networks XM (rev 1.0) board",
- - ubnt_xm_init);
- --- a/arch/mips/ath79/machtypes.h
- +++ /dev/null
- @@ -1,28 +0,0 @@
- -/*
- - * Atheros AR71XX/AR724X/AR913X machine type definitions
- - *
- - * Copyright (C) 2008-2010 Gabor Juhos <juhosg@openwrt.org>
- - * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
- - *
- - * This program is free software; you can redistribute it and/or modify it
- - * under the terms of the GNU General Public License version 2 as published
- - * by the Free Software Foundation.
- - */
- -
- -#ifndef _ATH79_MACHTYPE_H
- -#define _ATH79_MACHTYPE_H
- -
- -#include <asm/mips_machine.h>
- -
- -enum ath79_mach_type {
- - ATH79_MACH_GENERIC_OF = -1, /* Device tree board */
- - ATH79_MACH_GENERIC = 0,
- - ATH79_MACH_AP121, /* Atheros AP121 reference board */
- - ATH79_MACH_AP136_010, /* Atheros AP136-010 reference board */
- - ATH79_MACH_AP81, /* Atheros AP81 reference board */
- - ATH79_MACH_DB120, /* Atheros DB120 reference board */
- - ATH79_MACH_PB44, /* Atheros PB44 reference board */
- - ATH79_MACH_UBNT_XM, /* Ubiquiti Networks XM board rev 1.0 */
- -};
- -
- -#endif /* _ATH79_MACHTYPE_H */
- --- a/arch/mips/ath79/setup.c
- +++ b/arch/mips/ath79/setup.c
- @@ -33,7 +33,6 @@
- #include <asm/mach-ath79/ar71xx_regs.h>
- #include "common.h"
- #include "dev-common.h"
- -#include "machtypes.h"
-
- #define ATH79_SYS_TYPE_LEN 64
-
- @@ -230,25 +229,21 @@ void __init plat_mem_setup(void)
- else if (fw_passed_dtb)
- __dt_setup_arch((void *)KSEG0ADDR(fw_passed_dtb));
-
- - if (mips_machtype != ATH79_MACH_GENERIC_OF) {
- - ath79_reset_base = ioremap_nocache(AR71XX_RESET_BASE,
- - AR71XX_RESET_SIZE);
- - ath79_pll_base = ioremap_nocache(AR71XX_PLL_BASE,
- - AR71XX_PLL_SIZE);
- - ath79_detect_sys_type();
- - ath79_ddr_ctrl_init();
- + ath79_reset_base = ioremap_nocache(AR71XX_RESET_BASE,
- + AR71XX_RESET_SIZE);
- + ath79_pll_base = ioremap_nocache(AR71XX_PLL_BASE,
- + AR71XX_PLL_SIZE);
- + ath79_detect_sys_type();
- + ath79_ddr_ctrl_init();
-
- - detect_memory_region(0, ATH79_MEM_SIZE_MIN, ATH79_MEM_SIZE_MAX);
- -
- - /* OF machines should use the reset driver */
- - _machine_restart = ath79_restart;
- - }
- + detect_memory_region(0, ATH79_MEM_SIZE_MIN, ATH79_MEM_SIZE_MAX);
-
- + _machine_restart = ath79_restart;
- _machine_halt = ath79_halt;
- pm_power_off = ath79_halt;
- }
-
- -static void __init ath79_of_plat_time_init(void)
- +void __init plat_time_init(void)
- {
- struct device_node *np;
- struct clk *clk;
- @@ -278,66 +273,12 @@ static void __init ath79_of_plat_time_in
- clk_put(clk);
- }
-
- -void __init plat_time_init(void)
- -{
- - unsigned long cpu_clk_rate;
- - unsigned long ahb_clk_rate;
- - unsigned long ddr_clk_rate;
- - unsigned long ref_clk_rate;
- -
- - if (IS_ENABLED(CONFIG_OF) && mips_machtype == ATH79_MACH_GENERIC_OF) {
- - ath79_of_plat_time_init();
- - return;
- - }
- -
- - ath79_clocks_init();
- -
- - cpu_clk_rate = ath79_get_sys_clk_rate("cpu");
- - ahb_clk_rate = ath79_get_sys_clk_rate("ahb");
- - ddr_clk_rate = ath79_get_sys_clk_rate("ddr");
- - ref_clk_rate = ath79_get_sys_clk_rate("ref");
- -
- - pr_info("Clocks: CPU:%lu.%03luMHz, DDR:%lu.%03luMHz, AHB:%lu.%03luMHz, Ref:%lu.%03luMHz\n",
- - cpu_clk_rate / 1000000, (cpu_clk_rate / 1000) % 1000,
- - ddr_clk_rate / 1000000, (ddr_clk_rate / 1000) % 1000,
- - ahb_clk_rate / 1000000, (ahb_clk_rate / 1000) % 1000,
- - ref_clk_rate / 1000000, (ref_clk_rate / 1000) % 1000);
- -
- - mips_hpt_frequency = cpu_clk_rate / 2;
- -}
- -
- void __init arch_init_irq(void)
- {
- irqchip_init();
- }
-
- -static int __init ath79_setup(void)
- -{
- - if (mips_machtype == ATH79_MACH_GENERIC_OF)
- - return 0;
- -
- - ath79_gpio_init();
- - ath79_register_uart();
- - ath79_register_wdt();
- -
- - mips_machine_setup();
- -
- - return 0;
- -}
- -
- -arch_initcall(ath79_setup);
- -
- void __init device_tree_init(void)
- {
- unflatten_and_copy_device_tree();
- }
- -
- -MIPS_MACHINE(ATH79_MACH_GENERIC,
- - "Generic",
- - "Generic AR71XX/AR724X/AR913X based board",
- - NULL);
- -
- -MIPS_MACHINE(ATH79_MACH_GENERIC_OF,
- - "DTB",
- - "Generic AR71XX/AR724X/AR913X based board (DT)",
- - NULL);
|