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
// SPDX-License-Identifier: GPL-2.0+ // // Copyright (c) 2004-2005 Simtec Electronics // http://armlinux.simtec.co.uk/ // Ben Dooks <ben@simtec.co.uk> // // S3C2442 core and lock support #include <linux/init.h> #include <linux/module.h> #include <linux/kernel.h> #include <linux/list.h> #include <linux/errno.h> #include <linux/err.h> #include <linux/device.h> #include <linux/syscore_ops.h> #include <linux/interrupt.h> #include <linux/ioport.h> #include <linux/mutex.h> #include <linux/gpio.h> #include <linux/clk.h> #include <linux/io.h> #include <mach/hardware.h> #include <mach/gpio-samsung.h> #include <linux/atomic.h> #include <asm/irq.h> #include <mach/regs-clock.h> #include <plat/cpu.h> #include <plat/pm.h> #include <plat/gpio-core.h> #include <plat/gpio-cfg.h> #include <plat/gpio-cfg-helpers.h> #include "common.h" static struct device s3c2442_dev = { .bus = &s3c2442_subsys, }; int __init s3c2442_init(void) { printk("S3C2442: Initialising architecture\n"); #ifdef CONFIG_PM_SLEEP register_syscore_ops(&s3c2410_pm_syscore_ops); register_syscore_ops(&s3c24xx_irq_syscore_ops); register_syscore_ops(&s3c244x_pm_syscore_ops); #endif return device_register(&s3c2442_dev); } void __init s3c2442_map_io(void) { s3c244x_map_io(); s3c24xx_gpiocfg_default.set_pull = s3c24xx_gpio_setpull_1down; s3c24xx_gpiocfg_default.get_pull = s3c24xx_gpio_getpull_1down; }