aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/brcm2708
Commit message (Expand)AuthorAgeFilesLines
* kernel: update 3.10 to 3.10.3Gabor Juhos2013-07-262-2/+2
* kernel: update 3.10 to 3.10.2Gabor Juhos2013-07-2217-739/+531
* linux: move more ARM_ERRATA symbols to the generic configGabor Juhos2013-07-201-2/+0
* linux: remove duplicated 3.10 symbols from target config filesGabor Juhos2013-07-201-2/+0
* kernel: update to kernel 3.10.1 and refresh patchesHauke Mehrtens2013-07-131-1/+1
* brcm2708: drop support for 3.3 kernelFlorian Fainelli2013-07-1010-86421/+0
* brcm2708: package the i2c master driver moduleFlorian Fainelli2013-07-101-0/+18
* brcm2708: package the SPI master controller driverFlorian Fainelli2013-07-101-0/+19
* brcm2708: package the HW random moduleFlorian Fainelli2013-07-101-0/+14
* brcm2708: update maintainershipFlorian Fainelli2013-07-091-2/+2
* brcm2708: switch to 3.10 kernelFlorian Fainelli2013-07-091-1/+1
* brcm2708: add support for 3.10 kernelFlorian Fainelli2013-07-0917-0/+91057
* brcm2708: make it boot on revision 2 raspberry pisJonas Gorski2013-05-202-9/+924
* build: consistently use 'depends on' instead of 'depends'Felix Fietkau2013-04-171-1/+1
* target: enable XZ BCJ decompressor code after r35097Florian Fainelli2013-01-141-0/+2
* remove common symbols from 3.3 configsGabor Juhos2012-11-291-2/+0
* target: refresh all target configs with kconfig.plGabor Juhos2012-10-291-1/+1
* get rid of the IRQF_SAMPLE_RANDOM flagFlorian Fainelli2012-09-261-1/+1
* tools/firmware-utils/ptgen option to use MB roundingJohn Crispin2012-08-221-1/+1
* add more missing config symbolsFlorian Fainelli2012-07-261-10/+13
* cleanup config-3.3, remove =mJohn Crispin2012-07-251-63/+0
* adds target used by rapsberry piJohn Crispin2012-07-2419-0/+86651
nos pre.special { color: #000000; background-color: #ffffc0; padding: 0 5px 0 5px; } span.linenos.special { color: #000000; background-color: #ffffc0; padding: 0 5px 0 5px; } .highlight .hll { background-color: #ffffcc } .highlight { background: #ffffff; } .highlight .c { color: #888888 } /* Comment */ .highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */ .highlight .k { color: #008800; font-weight: bold } /* Keyword */ .highlight .ch { color: #888888 } /* Comment.Hashbang */ .highlight .cm { color: #888888 } /* Comment.Multiline */ .highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */ .highlight .cpf { color: #888888 } /* Comment.PreprocFile */ .highlight .c1 { color: #888888 } /* Comment.Single */ .highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */ .highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */ .highlight .ge { font-style: italic } /* Generic.Emph */ .highlight .gr { color: #aa0000 } /* Generic.Error */ .highlight .gh { color: #333333 } /* Generic.Heading */ .highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */ .highlight .go { color: #888888 } /* Generic.Output */ .highlight .gp { color: #555555 } /* Generic.Prompt */ .highlight .gs { font-weight: bold } /* Generic.Strong */ .highlight .gu { color: #666666 } /* Generic.Subheading */ .highlight .gt { color: #aa0000 } /* Generic.Traceback */ .highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */ .highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */ .highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */ .highlight .kp { color: #008800 } /* Keyword.Pseudo */ .highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */ .highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */ .highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */ .highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */ .highlight .na { color: #336699 } /* Name.Attribute */ .highlight .nb { color: #003388 } /* Name.Builtin */ .highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */ .highlight .no { color: #003366; font-weight: bold } /* Name.Constant */ .highlight .nd { color: #555555 } /* Name.Decorator */ .highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */ .highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */ .highlight .nl { color: #336699; font-style: italic } /* Name.Label */ .highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */ .highlight .py { color: #336699; font-weight: bold } /* Name.Property */ .highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */ .highlight .nv { color: #336699 } /* Name.Variable */ .highlight .ow { color: #008800 } /* Operator.Word */ .highlight .w { color: #bbbbbb } /* Text.Whitespace */ .highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */
#include <linux/autoconf.h>

#include <linux/module.h>
#include <linux/sched.h>
#include <linux/slab.h>
#include <linux/ioport.h>
#include <linux/errno.h>
#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/string.h>
#include <linux/poll.h>
#include <linux/init.h>
#include <linux/interrupt.h>

#include <asm/uaccess.h>
#include <linux/gpio_syscalls.h>

#include <asm/etraxgpio.h>
#include <asm/arch/svinto.h>
#include <asm/io.h>
#include <asm/system.h>
#include <asm/irq.h>
#include <asm/arch/io_interface_mux.h>

#include <asm/unistd.h>


extern int errno;


asmlinkage void sys_gpiosetbits(unsigned char port, unsigned int bits){
	switch(port){
	case 'G':
	case 'g':
		*R_PORT_G_DATA = port_g_data_shadow |= bits;
		break;
		
	case 'A':
	case 'a':
		*R_PORT_PA_DATA = port_pa_data_shadow |= bits;
		break;

	case 'B':
	case 'b':
		*R_PORT_PB_DATA = port_pb_data_shadow |= bits;
		break;
		
	};
};


asmlinkage void sys_gpioclearbits(unsigned char port, unsigned int bits){
	switch(port){
	case 'G':
	case 'g':
		*R_PORT_G_DATA = port_g_data_shadow &= ~bits;
		break;
		
	case 'A':
	case 'a':
		*R_PORT_PA_DATA = port_pa_data_shadow &= ~bits;
		break;

	case 'B':
	case 'b':
		*R_PORT_PB_DATA = port_pb_data_shadow &= ~bits;
		break;
		
	};
};

asmlinkage void sys_gpiosetdir(unsigned char port, unsigned char dir, unsigned int bits){
	if((dir=='I' )||(dir=='i')){
		switch(port){
		case 'G':
		case 'g':
			if(bits & (1<<0)){
				genconfig_shadow &= ~IO_MASK(R_GEN_CONFIG, g0dir);
			};
			if((bits & 0x0000FF00)==0x0000FF00){
				genconfig_shadow &= ~IO_MASK(R_GEN_CONFIG, g8_15dir);
			};			
			if((bits & 0x00FF0000)==0x00FF0000){
				genconfig_shadow &= ~IO_MASK(R_GEN_CONFIG, g16_23dir);
			};			
			if(bits & (1<<24)){
				genconfig_shadow &= ~IO_MASK(R_GEN_CONFIG, g24dir);
			};			
			*R_GEN_CONFIG = genconfig_shadow;
			break;
		
		case 'A':
		case 'a':
			*R_PORT_PA_DIR = port_pa_dir_shadow &= ~(bits & 0xff);
			break;

		case 'B':
		case 'b':
			*R_PORT_PB_DIR = port_pb_dir_shadow &= ~(bits & 0xff);
			break;
		};
	} else if((dir=='O' )||(dir=='o')){
		switch(port){
		case 'G':
		case 'g':
			if(bits & (1<<0)){
				genconfig_shadow |= IO_MASK(R_GEN_CONFIG, g0dir);
			};
			if((bits & 0x0000FF00)==0x0000FF00){
				genconfig_shadow |= IO_MASK(R_GEN_CONFIG, g8_15dir);
			};			
			if((bits & 0x00FF0000)==0x00FF0000){
				genconfig_shadow |= IO_MASK(R_GEN_CONFIG, g8_15dir);
			};			
			if(bits & (1<<24)){
				genconfig_shadow |= IO_MASK(R_GEN_CONFIG, g24dir);
			};			
			*R_GEN_CONFIG = genconfig_shadow;
			break;
		
		case 'A':
		case 'a':
			*R_PORT_PA_DIR = port_pa_dir_shadow |= (bits & 0xff);
			break;

		case 'B':
		case 'b':
			*R_PORT_PB_DIR = port_pb_dir_shadow |= (bits & 0xff);
			break;
		};
	};
};


asmlinkage void sys_gpiotogglebit(unsigned char port, unsigned int bits){
	switch(port){
	case 'G':
	case 'g':
		if(port_g_data_shadow & bits){
			*R_PORT_G_DATA = port_g_data_shadow &= ~bits;
		} else {
			*R_PORT_G_DATA = port_g_data_shadow |= bits;
		};
		break;
		
	case 'A':
	case 'a':
		if(*R_PORT_PA_DATA & bits){
			*R_PORT_PA_DATA = port_pa_data_shadow &= ~(bits & 0xff);
		} else {
			*R_PORT_PA_DATA = port_pa_data_shadow |= (bits & 0xff);	
		};
		break;

	case 'B':
	case 'b':
		if(*R_PORT_PB_DATA & bits){
			*R_PORT_PB_DATA = port_pb_data_shadow &= ~(bits & 0xff);
		} else {
			*R_PORT_PB_DATA = port_pb_data_shadow |= (bits & 0xff);	
		};
		break;
		
	};
};


asmlinkage unsigned int sys_gpiogetbits(unsigned char port, unsigned int bits){
	unsigned int data = 0;
	switch(port){
	case 'G':
	case 'g':
		data = *R_PORT_G_DATA;
		break;
		
	case 'A':
	case 'a':
		data = *R_PORT_PA_DATA;
		break;

	case 'B':
	case 'b':
		data = *R_PORT_PB_DATA;
		break;
		
	};
	data &= bits;
	return data;
};