mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-31 14:04:26 -04:00 
			
		
		
		
	This builds and boots. Because of the function pointer indirection (e.g. mtd_info's read function pointer is assigned to spiflash_read), it is difficult for me to understand where the calls are coming from (could be anywhere, conditionally pointing at spiflash versions), so I punted and used the renamed function pointers (_erase, _read, _write). If someone knows better what to do, please fix. Cleaned up other sundry kernel tracking issues like get_phy_id and __devinit,etc. [juhosg: don't switch to that yet] Signed-off-by: Russell Senior <russell@personaltelco.net> Signed-off-by: Gabor Juhos <juhosg@openwrt.org> SVN-Revision: 35727
		
			
				
	
	
		
			73 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| --- a/arch/mips/ar231x/Makefile
 | |
| +++ b/arch/mips/ar231x/Makefile
 | |
| @@ -8,7 +8,7 @@
 | |
|  # Copyright (C) 2006-2009 Felix Fietkau <nbd@openwrt.org>
 | |
|  #
 | |
|  
 | |
| -obj-y += board.o prom.o devices.o
 | |
| +obj-y += board.o prom.o devices.o reset.o
 | |
|  
 | |
|  obj-$(CONFIG_EARLY_PRINTK) += early_printk.o
 | |
|  
 | |
| --- /dev/null
 | |
| +++ b/arch/mips/ar231x/reset.c
 | |
| @@ -0,0 +1,58 @@
 | |
| +#include <linux/init.h>
 | |
| +#include <linux/slab.h>
 | |
| +#include <linux/platform_device.h>
 | |
| +#include <linux/gpio_keys.h>
 | |
| +#include <linux/input.h>
 | |
| +#include <ar231x_platform.h>
 | |
| +#include <ar231x.h>
 | |
| +#include "devices.h"
 | |
| +
 | |
| +static int __init
 | |
| +ar231x_init_reset(void)
 | |
| +{
 | |
| +	struct platform_device *pdev;
 | |
| +	struct gpio_keys_platform_data pdata;
 | |
| +	struct gpio_keys_button *p;
 | |
| +	int err;
 | |
| +
 | |
| +	if (ar231x_board.config->resetConfigGpio == 0xffff)
 | |
| +		return -ENODEV;
 | |
| +
 | |
| +	p = kzalloc(sizeof(*p), GFP_KERNEL);
 | |
| +	if (!p)
 | |
| +		goto err;
 | |
| +
 | |
| +	p->desc = "reset";
 | |
| +	p->type = EV_KEY;
 | |
| +	p->code = KEY_RESTART;
 | |
| +	p->debounce_interval = 60;
 | |
| +	p->gpio = ar231x_board.config->resetConfigGpio;
 | |
| +
 | |
| +	memset(&pdata, 0, sizeof(pdata));
 | |
| +	pdata.poll_interval = 20;
 | |
| +	pdata.buttons = p;
 | |
| +	pdata.nbuttons = 1;
 | |
| +
 | |
| +	pdev = platform_device_alloc("gpio-keys-polled", 0);
 | |
| +	if (!pdev)
 | |
| +		goto err_free;
 | |
| +
 | |
| +	err = platform_device_add_data(pdev, &pdata, sizeof(pdata));
 | |
| +	if (err)
 | |
| +		goto err_put_pdev;
 | |
| +
 | |
| +	err = platform_device_add(pdev);
 | |
| +	if (err)
 | |
| +		goto err_put_pdev;
 | |
| +
 | |
| +	return 0;
 | |
| +
 | |
| +err_put_pdev:
 | |
| +	platform_device_put(pdev);
 | |
| +err_free:
 | |
| +	kfree(p);
 | |
| +err:
 | |
| +	return -ENOMEM;
 | |
| +}
 | |
| +
 | |
| +module_init(ar231x_init_reset);
 |