mirror of
https://github.com/torvalds/linux.git
synced 2024-11-10 14:11:52 +00:00
ARM: pxa: remove Intel Imote2 and Stargate 2 boards
I have no reason to believe these boards have any more users and I haven't tested them for several years. Removing them may simplify other changes to the various PXA boards people still care about. The recent conversion of pxa2xx_spi to GPIO descriptors for example had to update this board despite no one caring or testing. Great boards that got me started in kernel development, RIP! Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> Acked-by: Mark Brown <broonie@kernel.org> Acked-by: Daniel Mack <daniel@zonque.org> Cc: Robert Jarzmik <robert.jarzmik@free.fr> Cc: Haojian Zhuang <haojian.zhuang@gmail.com> Cc: soc@kernel.org Link: https://lore.kernel.org/r/20220227134431.908998-1-jic23@kernel.org' Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
4036b29a14
commit
28f74201e3
@ -2116,13 +2116,6 @@ F: Documentation/devicetree/bindings/arm/intel,keembay.yaml
|
||||
F: arch/arm64/boot/dts/intel/keembay-evm.dts
|
||||
F: arch/arm64/boot/dts/intel/keembay-soc.dtsi
|
||||
|
||||
ARM/INTEL RESEARCH IMOTE/STARGATE 2 MACHINE SUPPORT
|
||||
M: Jonathan Cameron <jic23@cam.ac.uk>
|
||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||
S: Maintained
|
||||
F: arch/arm/mach-pxa/stargate2.c
|
||||
F: drivers/pcmcia/pxa2xx_stargate2.c
|
||||
|
||||
ARM/INTEL XSC3 (MANZANO) ARM CORE
|
||||
M: Lennert Buytenhek <kernel@wantstofly.org>
|
||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||
|
@ -41,8 +41,6 @@ CONFIG_MACH_EXEDA=y
|
||||
CONFIG_MACH_CM_X300=y
|
||||
CONFIG_MACH_CAPC7117=y
|
||||
CONFIG_ARCH_GUMSTIX=y
|
||||
CONFIG_MACH_INTELMOTE2=y
|
||||
CONFIG_MACH_STARGATE2=y
|
||||
CONFIG_MACH_XCEP=y
|
||||
CONFIG_TRIZEPS_PXA=y
|
||||
CONFIG_MACH_TRIZEPS4WL=y
|
||||
@ -487,7 +485,6 @@ CONFIG_SND_SOC_ZYLONITE=m
|
||||
CONFIG_SND_PXA2XX_SOC_HX4700=m
|
||||
CONFIG_SND_PXA2XX_SOC_MAGICIAN=m
|
||||
CONFIG_SND_PXA2XX_SOC_MIOA701=m
|
||||
CONFIG_SND_PXA2XX_SOC_IMOTE2=m
|
||||
CONFIG_SND_SOC_AK4642=m
|
||||
CONFIG_SND_SOC_WM8978=m
|
||||
CONFIG_SND_SIMPLE_CARD=m
|
||||
|
@ -153,16 +153,6 @@ config GUMSTIX_AM300EPD
|
||||
|
||||
endchoice
|
||||
|
||||
config MACH_INTELMOTE2
|
||||
bool "Intel Mote 2 Platform"
|
||||
select IWMMXT
|
||||
select PXA27x
|
||||
|
||||
config MACH_STARGATE2
|
||||
bool "Intel Stargate 2 Platform"
|
||||
select IWMMXT
|
||||
select PXA27x
|
||||
|
||||
config MACH_XCEP
|
||||
bool "Iskratel Electronics XCEP"
|
||||
select MTD
|
||||
|
@ -45,8 +45,6 @@ obj-$(CONFIG_MACH_CAPC7117) += capc7117.o mxm8x10.o
|
||||
obj-$(CONFIG_ARCH_GUMSTIX) += gumstix.o
|
||||
obj-$(CONFIG_GUMSTIX_AM200EPD) += am200epd.o
|
||||
obj-$(CONFIG_GUMSTIX_AM300EPD) += am300epd.o
|
||||
obj-$(CONFIG_MACH_INTELMOTE2) += stargate2.o
|
||||
obj-$(CONFIG_MACH_STARGATE2) += stargate2.o
|
||||
obj-$(CONFIG_MACH_XCEP) += xcep.o
|
||||
obj-$(CONFIG_MACH_TRIZEPS4) += trizeps4.o
|
||||
obj-$(CONFIG_MACH_LOGICPD_PXA270) += lpd270.o
|
||||
|
@ -58,8 +58,7 @@ static inline void arch_decomp_setup(void)
|
||||
uart_shift = 2;
|
||||
uart_is_pxa = 1;
|
||||
|
||||
if (machine_is_littleton() || machine_is_intelmote2()
|
||||
|| machine_is_csb726() || machine_is_stargate2()
|
||||
if (machine_is_littleton() || machine_is_csb726() ||
|
||||
|| machine_is_cm_x300() || machine_is_balloon3())
|
||||
uart_base = STUART_BASE;
|
||||
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -210,7 +210,7 @@ config PCMCIA_PXA2XX
|
||||
depends on ARM && ARCH_PXA && PCMCIA
|
||||
depends on (ARCH_LUBBOCK || MACH_MAINSTONE || PXA_SHARPSL \
|
||||
|| ARCH_PXA_PALM || TRIZEPS_PCMCIA \
|
||||
|| ARCOM_PCMCIA || ARCH_PXA_ESERIES || MACH_STARGATE2 \
|
||||
|| ARCOM_PCMCIA || ARCH_PXA_ESERIES \
|
||||
|| MACH_VPAC270 || MACH_BALLOON3 || MACH_COLIBRI \
|
||||
|| MACH_COLIBRI320 || MACH_H4700)
|
||||
select PCMCIA_SOC_COMMON
|
||||
|
@ -56,7 +56,6 @@ pxa2xx-obj-$(CONFIG_MACH_PALMTX) += pxa2xx_palmtx.o
|
||||
pxa2xx-obj-$(CONFIG_MACH_PALMTC) += pxa2xx_palmtc.o
|
||||
pxa2xx-obj-$(CONFIG_MACH_PALMLD) += pxa2xx_palmld.o
|
||||
pxa2xx-obj-$(CONFIG_MACH_E740) += pxa2xx_e740.o
|
||||
pxa2xx-obj-$(CONFIG_MACH_STARGATE2) += pxa2xx_stargate2.o
|
||||
pxa2xx-obj-$(CONFIG_MACH_VPAC270) += pxa2xx_vpac270.o
|
||||
pxa2xx-obj-$(CONFIG_MACH_BALLOON3) += pxa2xx_balloon3.o
|
||||
pxa2xx-obj-$(CONFIG_MACH_COLIBRI) += pxa2xx_colibri.o
|
||||
|
@ -1,137 +0,0 @@
|
||||
// SPDX-License-Identifier: GPL-2.0-only
|
||||
/*
|
||||
* linux/drivers/pcmcia/pxa2xx_stargate2.c
|
||||
*
|
||||
* Stargate 2 PCMCIA specific routines.
|
||||
*
|
||||
* Created: December 6, 2005
|
||||
* Author: Ed C. Epp
|
||||
* Copyright: Intel Corp 2005
|
||||
* Jonathan Cameron <jic23@cam.ac.uk> 2009
|
||||
*/
|
||||
|
||||
#include <linux/module.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/gpio.h>
|
||||
|
||||
#include <pcmcia/ss.h>
|
||||
|
||||
#include <asm/irq.h>
|
||||
#include <asm/mach-types.h>
|
||||
|
||||
#include "soc_common.h"
|
||||
|
||||
#define SG2_S0_POWER_CTL 108
|
||||
#define SG2_S0_GPIO_RESET 82
|
||||
#define SG2_S0_GPIO_DETECT 53
|
||||
#define SG2_S0_GPIO_READY 81
|
||||
|
||||
static struct gpio sg2_pcmcia_gpios[] = {
|
||||
{ SG2_S0_GPIO_RESET, GPIOF_OUT_INIT_HIGH, "PCMCIA Reset" },
|
||||
{ SG2_S0_POWER_CTL, GPIOF_OUT_INIT_HIGH, "PCMCIA Power Ctrl" },
|
||||
};
|
||||
|
||||
static int sg2_pcmcia_hw_init(struct soc_pcmcia_socket *skt)
|
||||
{
|
||||
skt->stat[SOC_STAT_CD].gpio = SG2_S0_GPIO_DETECT;
|
||||
skt->stat[SOC_STAT_CD].name = "PCMCIA0 CD";
|
||||
skt->stat[SOC_STAT_RDY].gpio = SG2_S0_GPIO_READY;
|
||||
skt->stat[SOC_STAT_RDY].name = "PCMCIA0 RDY";
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void sg2_pcmcia_socket_state(struct soc_pcmcia_socket *skt,
|
||||
struct pcmcia_state *state)
|
||||
{
|
||||
state->bvd1 = 0; /* not available - battery detect on card */
|
||||
state->bvd2 = 0; /* not available */
|
||||
state->vs_3v = 1; /* not available - voltage detect for card */
|
||||
state->vs_Xv = 0; /* not available */
|
||||
}
|
||||
|
||||
static int sg2_pcmcia_configure_socket(struct soc_pcmcia_socket *skt,
|
||||
const socket_state_t *state)
|
||||
{
|
||||
/* Enable card power */
|
||||
switch (state->Vcc) {
|
||||
case 0:
|
||||
/* sets power ctl register high */
|
||||
gpio_set_value(SG2_S0_POWER_CTL, 1);
|
||||
break;
|
||||
case 33:
|
||||
case 50:
|
||||
/* sets power control register low (clear) */
|
||||
gpio_set_value(SG2_S0_POWER_CTL, 0);
|
||||
msleep(100);
|
||||
break;
|
||||
default:
|
||||
pr_err("%s(): bad Vcc %u\n",
|
||||
__func__, state->Vcc);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* reset */
|
||||
gpio_set_value(SG2_S0_GPIO_RESET, !!(state->flags & SS_RESET));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct pcmcia_low_level sg2_pcmcia_ops __initdata = {
|
||||
.owner = THIS_MODULE,
|
||||
.hw_init = sg2_pcmcia_hw_init,
|
||||
.socket_state = sg2_pcmcia_socket_state,
|
||||
.configure_socket = sg2_pcmcia_configure_socket,
|
||||
.nr = 1,
|
||||
};
|
||||
|
||||
static struct platform_device *sg2_pcmcia_device;
|
||||
|
||||
static int __init sg2_pcmcia_init(void)
|
||||
{
|
||||
int ret;
|
||||
|
||||
if (!machine_is_stargate2())
|
||||
return -ENODEV;
|
||||
|
||||
sg2_pcmcia_device = platform_device_alloc("pxa2xx-pcmcia", -1);
|
||||
if (!sg2_pcmcia_device)
|
||||
return -ENOMEM;
|
||||
|
||||
ret = gpio_request_array(sg2_pcmcia_gpios, ARRAY_SIZE(sg2_pcmcia_gpios));
|
||||
if (ret)
|
||||
goto error_put_platform_device;
|
||||
|
||||
ret = platform_device_add_data(sg2_pcmcia_device,
|
||||
&sg2_pcmcia_ops,
|
||||
sizeof(sg2_pcmcia_ops));
|
||||
if (ret)
|
||||
goto error_free_gpios;
|
||||
|
||||
ret = platform_device_add(sg2_pcmcia_device);
|
||||
if (ret)
|
||||
goto error_free_gpios;
|
||||
|
||||
return 0;
|
||||
error_free_gpios:
|
||||
gpio_free_array(sg2_pcmcia_gpios, ARRAY_SIZE(sg2_pcmcia_gpios));
|
||||
error_put_platform_device:
|
||||
platform_device_put(sg2_pcmcia_device);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static void __exit sg2_pcmcia_exit(void)
|
||||
{
|
||||
platform_device_unregister(sg2_pcmcia_device);
|
||||
gpio_free_array(sg2_pcmcia_gpios, ARRAY_SIZE(sg2_pcmcia_gpios));
|
||||
}
|
||||
|
||||
fs_initcall(sg2_pcmcia_init);
|
||||
module_exit(sg2_pcmcia_exit);
|
||||
|
||||
MODULE_LICENSE("GPL");
|
||||
MODULE_ALIAS("platform:pxa2xx-pcmcia");
|
@ -220,15 +220,6 @@ config SND_PXA2XX_SOC_MIOA701
|
||||
Say Y if you want to add support for SoC audio on the
|
||||
MIO A701.
|
||||
|
||||
config SND_PXA2XX_SOC_IMOTE2
|
||||
tristate "SoC Audio support for IMote 2"
|
||||
depends on SND_PXA2XX_SOC && MACH_INTELMOTE2 && I2C
|
||||
select SND_PXA2XX_SOC_I2S
|
||||
select SND_SOC_WM8940
|
||||
help
|
||||
Say Y if you want to add support for SoC audio on the
|
||||
IMote 2.
|
||||
|
||||
config SND_MMP_SOC_BROWNSTONE
|
||||
tristate "SoC Audio support for Marvell Brownstone"
|
||||
depends on SND_MMP_SOC_SSPA && MACH_BROWNSTONE && I2C
|
||||
|
@ -29,7 +29,6 @@ snd-soc-hx4700-objs := hx4700.o
|
||||
snd-soc-magician-objs := magician.o
|
||||
snd-soc-mioa701-objs := mioa701_wm9713.o
|
||||
snd-soc-z2-objs := z2.o
|
||||
snd-soc-imote2-objs := imote2.o
|
||||
snd-soc-brownstone-objs := brownstone.o
|
||||
snd-soc-ttc-dkb-objs := ttc-dkb.o
|
||||
|
||||
@ -47,6 +46,5 @@ obj-$(CONFIG_SND_PXA2XX_SOC_MAGICIAN) += snd-soc-magician.o
|
||||
obj-$(CONFIG_SND_PXA2XX_SOC_MIOA701) += snd-soc-mioa701.o
|
||||
obj-$(CONFIG_SND_PXA2XX_SOC_Z2) += snd-soc-z2.o
|
||||
obj-$(CONFIG_SND_SOC_ZYLONITE) += snd-soc-zylonite.o
|
||||
obj-$(CONFIG_SND_PXA2XX_SOC_IMOTE2) += snd-soc-imote2.o
|
||||
obj-$(CONFIG_SND_MMP_SOC_BROWNSTONE) += snd-soc-brownstone.o
|
||||
obj-$(CONFIG_SND_SOC_TTC_DKB) += snd-soc-ttc-dkb.o
|
||||
|
@ -1,99 +0,0 @@
|
||||
// SPDX-License-Identifier: GPL-2.0-only
|
||||
|
||||
#include <linux/module.h>
|
||||
#include <sound/soc.h>
|
||||
|
||||
#include <asm/mach-types.h>
|
||||
|
||||
#include "../codecs/wm8940.h"
|
||||
#include "pxa2xx-i2s.h"
|
||||
|
||||
static int imote2_asoc_hw_params(struct snd_pcm_substream *substream,
|
||||
struct snd_pcm_hw_params *params)
|
||||
{
|
||||
struct snd_soc_pcm_runtime *rtd = asoc_substream_to_rtd(substream);
|
||||
struct snd_soc_dai *codec_dai = asoc_rtd_to_codec(rtd, 0);
|
||||
struct snd_soc_dai *cpu_dai = asoc_rtd_to_cpu(rtd, 0);
|
||||
unsigned int clk = 0;
|
||||
int ret;
|
||||
|
||||
switch (params_rate(params)) {
|
||||
case 8000:
|
||||
case 16000:
|
||||
case 48000:
|
||||
case 96000:
|
||||
clk = 12288000;
|
||||
break;
|
||||
case 11025:
|
||||
case 22050:
|
||||
case 44100:
|
||||
clk = 11289600;
|
||||
break;
|
||||
}
|
||||
|
||||
ret = snd_soc_dai_set_sysclk(codec_dai, 0, clk,
|
||||
SND_SOC_CLOCK_IN);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
|
||||
/* set the I2S system clock as input (unused) */
|
||||
ret = snd_soc_dai_set_sysclk(cpu_dai, PXA2XX_I2S_SYSCLK, clk,
|
||||
SND_SOC_CLOCK_OUT);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static const struct snd_soc_ops imote2_asoc_ops = {
|
||||
.hw_params = imote2_asoc_hw_params,
|
||||
};
|
||||
|
||||
SND_SOC_DAILINK_DEFS(wm8940,
|
||||
DAILINK_COMP_ARRAY(COMP_CPU("pxa2xx-i2s")),
|
||||
DAILINK_COMP_ARRAY(COMP_CODEC("wm8940-codec.0-0034",
|
||||
"wm8940-hifi")),
|
||||
DAILINK_COMP_ARRAY(COMP_PLATFORM("pxa-pcm-audio")));
|
||||
|
||||
static struct snd_soc_dai_link imote2_dai = {
|
||||
.name = "WM8940",
|
||||
.stream_name = "WM8940",
|
||||
.dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF |
|
||||
SND_SOC_DAIFMT_CBS_CFS,
|
||||
.ops = &imote2_asoc_ops,
|
||||
SND_SOC_DAILINK_REG(wm8940),
|
||||
};
|
||||
|
||||
static struct snd_soc_card imote2 = {
|
||||
.name = "Imote2",
|
||||
.owner = THIS_MODULE,
|
||||
.dai_link = &imote2_dai,
|
||||
.num_links = 1,
|
||||
};
|
||||
|
||||
static int imote2_probe(struct platform_device *pdev)
|
||||
{
|
||||
struct snd_soc_card *card = &imote2;
|
||||
int ret;
|
||||
|
||||
card->dev = &pdev->dev;
|
||||
|
||||
ret = devm_snd_soc_register_card(&pdev->dev, card);
|
||||
if (ret)
|
||||
dev_err(&pdev->dev, "snd_soc_register_card() failed: %d\n",
|
||||
ret);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static struct platform_driver imote2_driver = {
|
||||
.driver = {
|
||||
.name = "imote2-audio",
|
||||
.pm = &snd_soc_pm_ops,
|
||||
},
|
||||
.probe = imote2_probe,
|
||||
};
|
||||
|
||||
module_platform_driver(imote2_driver);
|
||||
|
||||
MODULE_AUTHOR("Jonathan Cameron");
|
||||
MODULE_DESCRIPTION("ALSA SoC Imote 2");
|
||||
MODULE_LICENSE("GPL");
|
||||
MODULE_ALIAS("platform:imote2-audio");
|
Loading…
Reference in New Issue
Block a user