| /* | 
 |  * 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); | 
 | } |