Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 | // SPDX-License-Identifier: GPL-2.0-only /* * System Specific setup for Traverse Technologies GEOS. * At the moment this means setup of GPIO control of LEDs. * * Copyright (C) 2008 Constantin Baranov <const@mimas.ru> * Copyright (C) 2011 Ed Wildgoose <kernel@wildgooses.com> * and Philip Prindeville <philipp@redfish-solutions.com> * * TODO: There are large similarities with leds-net5501.c * by Alessandro Zummo <a.zummo@towertech.it> * In the future leds-net5501.c should be migrated over to platform */ #include <linux/kernel.h> #include <linux/init.h> #include <linux/io.h> #include <linux/string.h> #include <linux/leds.h> #include <linux/platform_device.h> #include <linux/input.h> #include <linux/gpio_keys.h> #include <linux/gpio/machine.h> #include <linux/dmi.h> #include <asm/geode.h> static struct gpio_keys_button geos_gpio_buttons[] = { { .code = KEY_RESTART, .gpio = 3, .active_low = 1, .desc = "Reset button", .type = EV_KEY, .wakeup = 0, .debounce_interval = 100, .can_disable = 0, } }; static struct gpio_keys_platform_data geos_buttons_data = { .buttons = geos_gpio_buttons, .nbuttons = ARRAY_SIZE(geos_gpio_buttons), .poll_interval = 20, }; static struct platform_device geos_buttons_dev = { .name = "gpio-keys-polled", .id = 1, .dev = { .platform_data = &geos_buttons_data, } }; static struct gpio_led geos_leds[] = { { .name = "geos:1", .default_trigger = "default-on", }, { .name = "geos:2", .default_trigger = "default-off", }, { .name = "geos:3", .default_trigger = "default-off", }, }; static struct gpio_led_platform_data geos_leds_data = { .num_leds = ARRAY_SIZE(geos_leds), .leds = geos_leds, }; static struct gpiod_lookup_table geos_leds_gpio_table = { .dev_id = "leds-gpio", .table = { /* The Geode GPIOs should be on the CS5535 companion chip */ GPIO_LOOKUP_IDX("cs5535-gpio", 6, NULL, 0, GPIO_ACTIVE_LOW), GPIO_LOOKUP_IDX("cs5535-gpio", 25, NULL, 1, GPIO_ACTIVE_LOW), GPIO_LOOKUP_IDX("cs5535-gpio", 27, NULL, 2, GPIO_ACTIVE_LOW), { } }, }; static struct platform_device geos_leds_dev = { .name = "leds-gpio", .id = -1, .dev.platform_data = &geos_leds_data, }; static struct platform_device *geos_devs[] __initdata = { &geos_buttons_dev, &geos_leds_dev, }; static void __init register_geos(void) { /* Setup LED control through leds-gpio driver */ gpiod_add_lookup_table(&geos_leds_gpio_table); platform_add_devices(geos_devs, ARRAY_SIZE(geos_devs)); } static int __init geos_init(void) { const char *vendor, *product; if (!is_geode()) return 0; vendor = dmi_get_system_info(DMI_SYS_VENDOR); if (!vendor || strcmp(vendor, "Traverse Technologies")) return 0; product = dmi_get_system_info(DMI_PRODUCT_NAME); if (!product || strcmp(product, "Geos")) return 0; printk(KERN_INFO "%s: system is recognized as \"%s %s\"\n", KBUILD_MODNAME, vendor, product); register_geos(); return 0; } device_initcall(geos_init); |