cregit-Linux how code gets into the kernel

Release 4.11 arch/arm/mach-ep93xx/simone.c

/*
 * arch/arm/mach-ep93xx/simone.c
 * Simplemachines Sim.One support.
 *
 * Copyright (C) 2010 Ryan Mallon
 *
 * Based on the 2.6.24.7 support:
 *   Copyright (C) 2009 Simplemachines
 *   MMC support by Peter Ivanov <ivanovp@gmail.com>, 2007
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or (at
 * your option) any later version.
 *
 */

#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/platform_device.h>
#include <linux/i2c.h>
#include <linux/i2c-gpio.h>
#include <linux/mmc/host.h>
#include <linux/spi/spi.h>
#include <linux/spi/mmc_spi.h>
#include <linux/platform_data/video-ep93xx.h>
#include <linux/platform_data/spi-ep93xx.h>
#include <linux/gpio.h>

#include <mach/hardware.h>
#include <mach/gpio-ep93xx.h>

#include <asm/mach-types.h>
#include <asm/mach/arch.h>

#include "soc.h"


static struct ep93xx_eth_data __initdata simone_eth_data = {
	.phy_id		= 1,
};


static struct ep93xxfb_mach_info __initdata simone_fb_info = {
	.flags		= EP93XXFB_USE_SDCSN0 | EP93XXFB_PCLK_FALLING,
};

/*
 * GPIO lines used for MMC card detection.
 */

#define MMC_CARD_DETECT_GPIO EP93XX_GPIO_LINE_EGPIO0

/*
 * MMC card detection GPIO setup.
 */


static int simone_mmc_spi_init(struct device *dev, irqreturn_t (*irq_handler)(int, void *), void *mmc) { unsigned int gpio = MMC_CARD_DETECT_GPIO; int irq, err; err = gpio_request(gpio, dev_name(dev)); if (err) return err; err = gpio_direction_input(gpio); if (err) goto fail; irq = gpio_to_irq(gpio); if (irq < 0) goto fail; err = request_irq(irq, irq_handler, IRQF_TRIGGER_FALLING, "MMC card detect", mmc); if (err) goto fail; printk(KERN_INFO "%s: using irq %d for MMC card detection\n", dev_name(dev), irq); return 0; fail: gpio_free(gpio); return err; }

Contributors

PersonTokensPropCommitsCommitProp
Mika Westerberg135100.00%1100.00%
Total135100.00%1100.00%


static void simone_mmc_spi_exit(struct device *dev, void *mmc) { unsigned int gpio = MMC_CARD_DETECT_GPIO; free_irq(gpio_to_irq(gpio), mmc); gpio_free(gpio); }

Contributors

PersonTokensPropCommitsCommitProp
Mika Westerberg36100.00%1100.00%
Total36100.00%1100.00%

static struct mmc_spi_platform_data simone_mmc_spi_data = { .init = simone_mmc_spi_init, .exit = simone_mmc_spi_exit, .detect_delay = 500, .ocr_mask = MMC_VDD_32_33 | MMC_VDD_33_34, }; static struct spi_board_info simone_spi_devices[] __initdata = { { .modalias = "mmc_spi", .platform_data = &simone_mmc_spi_data, /* * We use 10 MHz even though the maximum is 3.7 MHz. The driver * will limit it automatically to max. frequency. */ .max_speed_hz = 10 * 1000 * 1000, .bus_num = 0, .chip_select = 0, .mode = SPI_MODE_3, }, }; /* * Up to v1.3, the Sim.One used SFRMOUT as SD card chip select, but this goes * low between multi-message command blocks. From v1.4, it uses a GPIO instead. * v1.3 parts will still work, since the signal on SFRMOUT is automatic. */ static int simone_spi_chipselects[] __initdata = { EP93XX_GPIO_LINE_EGPIO1, }; static struct ep93xx_spi_info simone_spi_info __initdata = { .chipselect = simone_spi_chipselects, .num_chipselect = ARRAY_SIZE(simone_spi_chipselects), .use_dma = 1, }; static struct i2c_gpio_platform_data __initdata simone_i2c_gpio_data = { .sda_pin = EP93XX_GPIO_LINE_EEDAT, .sda_is_open_drain = 0, .scl_pin = EP93XX_GPIO_LINE_EECLK, .scl_is_open_drain = 0, .udelay = 0, .timeout = 0, }; static struct i2c_board_info __initdata simone_i2c_board_info[] = { { I2C_BOARD_INFO("ds1337", 0x68), }, }; static struct platform_device simone_audio_device = { .name = "simone-audio", .id = -1, };
static void __init simone_register_audio(void) { ep93xx_register_ac97(); platform_device_register(&simone_audio_device); }

Contributors

PersonTokensPropCommitsCommitProp
Mika Westerberg18100.00%1100.00%
Total18100.00%1100.00%


static void __init simone_init_machine(void) { ep93xx_init_devices(); ep93xx_register_flash(2, EP93XX_CS6_PHYS_BASE, SZ_8M); ep93xx_register_eth(&simone_eth_data, 1); ep93xx_register_fb(&simone_fb_info); ep93xx_register_i2c(&simone_i2c_gpio_data, simone_i2c_board_info, ARRAY_SIZE(simone_i2c_board_info)); ep93xx_register_spi(&simone_spi_info, simone_spi_devices, ARRAY_SIZE(simone_spi_devices)); simone_register_audio(); }

Contributors

PersonTokensPropCommitsCommitProp
Ryan Mallon4265.62%120.00%
Mika Westerberg1625.00%360.00%
H Hartley Sweeten69.38%120.00%
Total64100.00%5100.00%

MACHINE_START(SIM_ONE, "Simplemachines Sim.One Board") /* Maintainer: Ryan Mallon */ .atag_offset = 0x100, .map_io = ep93xx_map_io, .init_irq = ep93xx_init_irq, .init_time = ep93xx_timer_init, .init_machine = simone_init_machine, .init_late = ep93xx_init_late, .restart = ep93xx_restart, MACHINE_END

Overall Contributors

PersonTokensPropCommitsCommitProp
Mika Westerberg33659.36%318.75%
Ryan Mallon18232.16%318.75%
H Hartley Sweeten264.59%318.75%
Linus Walleij81.41%212.50%
Russell King50.88%16.25%
Shawn Guo50.88%16.25%
Stephen Warren20.35%16.25%
Nico Pitre10.18%16.25%
Arnd Bergmann10.18%16.25%
Total566100.00%16100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.