|  | /* | 
|  | * linux/arch/arm/mach-mmp/devices.c | 
|  | * | 
|  | * 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/init.h> | 
|  | #include <linux/platform_device.h> | 
|  | #include <linux/dma-mapping.h> | 
|  |  | 
|  | #include <asm/irq.h> | 
|  | #include <mach/devices.h> | 
|  |  | 
|  | int __init pxa_register_device(struct pxa_device_desc *desc, | 
|  | void *data, size_t size) | 
|  | { | 
|  | struct platform_device *pdev; | 
|  | struct resource res[2 + MAX_RESOURCE_DMA]; | 
|  | int i, ret = 0, nres = 0; | 
|  |  | 
|  | pdev = platform_device_alloc(desc->drv_name, desc->id); | 
|  | if (pdev == NULL) | 
|  | return -ENOMEM; | 
|  |  | 
|  | pdev->dev.coherent_dma_mask = DMA_BIT_MASK(32); | 
|  |  | 
|  | memset(res, 0, sizeof(res)); | 
|  |  | 
|  | if (desc->start != -1ul && desc->size > 0) { | 
|  | res[nres].start	= desc->start; | 
|  | res[nres].end	= desc->start + desc->size - 1; | 
|  | res[nres].flags	= IORESOURCE_MEM; | 
|  | nres++; | 
|  | } | 
|  |  | 
|  | if (desc->irq != NO_IRQ) { | 
|  | res[nres].start	= desc->irq; | 
|  | res[nres].end	= desc->irq; | 
|  | res[nres].flags	= IORESOURCE_IRQ; | 
|  | nres++; | 
|  | } | 
|  |  | 
|  | for (i = 0; i < MAX_RESOURCE_DMA; i++, nres++) { | 
|  | if (desc->dma[i] == 0) | 
|  | break; | 
|  |  | 
|  | res[nres].start	= desc->dma[i]; | 
|  | res[nres].end	= desc->dma[i]; | 
|  | res[nres].flags	= IORESOURCE_DMA; | 
|  | } | 
|  |  | 
|  | ret = platform_device_add_resources(pdev, res, nres); | 
|  | if (ret) { | 
|  | platform_device_put(pdev); | 
|  | return ret; | 
|  | } | 
|  |  | 
|  | if (data && size) { | 
|  | ret = platform_device_add_data(pdev, data, size); | 
|  | if (ret) { | 
|  | platform_device_put(pdev); | 
|  | return ret; | 
|  | } | 
|  | } | 
|  |  | 
|  | return platform_device_add(pdev); | 
|  | } |