| /* |
| * Copyright (C) 2006 Atmel Corporation |
| * |
| * 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. |
| */ |
| |
| #include <linux/clk.h> |
| #include <linux/err.h> |
| #include <linux/init.h> |
| #include <linux/platform_device.h> |
| |
| #include <asm/io.h> |
| |
| #include <asm/arch/init.h> |
| #include <asm/arch/sm.h> |
| |
| struct at32_sm system_manager; |
| |
| static int __init at32_sm_init(void) |
| { |
| struct resource *regs; |
| struct at32_sm *sm = &system_manager; |
| int ret = -ENXIO; |
| |
| regs = platform_get_resource(&at32_sm_device, IORESOURCE_MEM, 0); |
| if (!regs) |
| goto fail; |
| |
| spin_lock_init(&sm->lock); |
| sm->pdev = &at32_sm_device; |
| |
| ret = -ENOMEM; |
| sm->regs = ioremap(regs->start, regs->end - regs->start + 1); |
| if (!sm->regs) |
| goto fail; |
| |
| return 0; |
| |
| fail: |
| printk(KERN_ERR "Failed to initialize System Manager: %d\n", ret); |
| return ret; |
| } |
| |
| void __init setup_platform(void) |
| { |
| at32_sm_init(); |
| at32_clock_init(); |
| at32_portmux_init(); |
| } |
| |
| static int __init pdc_probe(struct platform_device *pdev) |
| { |
| struct clk *pclk, *hclk; |
| |
| pclk = clk_get(&pdev->dev, "pclk"); |
| if (IS_ERR(pclk)) { |
| dev_err(&pdev->dev, "no pclk defined\n"); |
| return PTR_ERR(pclk); |
| } |
| hclk = clk_get(&pdev->dev, "hclk"); |
| if (IS_ERR(hclk)) { |
| dev_err(&pdev->dev, "no hclk defined\n"); |
| clk_put(pclk); |
| return PTR_ERR(hclk); |
| } |
| |
| clk_enable(pclk); |
| clk_enable(hclk); |
| |
| dev_info(&pdev->dev, "Atmel Peripheral DMA Controller enabled\n"); |
| return 0; |
| } |
| |
| static struct platform_driver pdc_driver = { |
| .probe = pdc_probe, |
| .driver = { |
| .name = "pdc", |
| }, |
| }; |
| |
| static int __init pdc_init(void) |
| { |
| return platform_driver_register(&pdc_driver); |
| } |
| arch_initcall(pdc_init); |