/* * OMAP gcxxx device initialization * * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com * * 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. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. */ #include #include #include #include #include #include /* gc-core platform device data structure */ struct gccore_plat_data { void __iomem *base; int irq; }; static struct gccore_plat_data omap_gcxxx; struct omap_device_pm_latency omap_gcxxx_latency[] = { { .deactivate_func = omap_device_idle_hwmods, .activate_func = omap_device_enable_hwmods, .flags = OMAP_DEVICE_LATENCY_AUTO_ADJUST, } }; int __init gcxxx_init(void) { int retval = 0; struct omap_hwmod *oh; struct omap_device *od; const char *oh_name = "bb2d"; const char *dev_name = "gc-core"; if (!cpu_is_omap447x()) return retval; /* * Hwmod lookup will fail in case our platform doesn't support the * hardware spinlock module, so it is safe to run this initcall * on all omaps */ oh = omap_hwmod_lookup(oh_name); if (oh == NULL) return -EINVAL; omap_gcxxx.base = omap_hwmod_get_mpu_rt_va(oh); omap_gcxxx.irq = oh->mpu_irqs[0].irq; od = omap_device_build(dev_name, 0, oh, &omap_gcxxx, sizeof(omap_gcxxx), omap_gcxxx_latency, ARRAY_SIZE(omap_gcxxx_latency), false); if (IS_ERR(od)) { pr_err("Can't build omap_device for %s:%s\n", dev_name, oh_name); retval = PTR_ERR(od); } return retval; } device_initcall(gcxxx_init); MODULE_AUTHOR("David Sin"); MODULE_DESCRIPTION("omap gcxxx: omap device registration"); MODULE_LICENSE("GPL v2");