Linux GPIO子系统

一、Linux驱动程序

驱动程序为drivers\gpio\gpiolib-sysfs.c

二、通过SYSFS使用GPIO

如果只是简单的引脚控制(比如输出、查询输入值),可以不编写驱动程序,这样可以节省很多事情。

但是涉及中断的话,就需要编写驱动程序了。

2.1 设置GPIO方向,读写值

1、可通过串口输出命令验证

1、设置你想操作的GPIO Pin,这里我们假设用GPIO76

cd /sys/class/gpio/
echo 76 > export

2、设置GPIO Pin的方向:
echo "in" > gpio76   //for input direction
echo "out" > gpio76   //for outputdirection

3、设置输出GPIO Pin的值
echo 1 > gpio76/value  //for output high level
echo 0 > gpio76/value  //for output low level

4、读取GPIO Pin的值
cat gpio76/value    //1:higl level, 0:low level

2、通过应用程序操作

(1)读取指定GPIO Pin的值


int getGPIOValue(int gpio)
{
	int fd = -1,value;
	char filename[256] = {0};
	char buf[32] = {0};

	if (access("/sys/class/gpio/export",F_OK))
	{
		ALOGD("/sys/class/gpio/export is no exist");
		return -1;
	}

	if (access("/sys/class/gpio/unexport",F_OK))
	{
		ALOGD("/sys/class/gpio/unexport is no exist");
		return -1;
	}

	fd = open("/sys/class/gpio/export",O_WRONLY);
	if (fd < 0)
	{
		ALOGD("open /sys/class/gpio/export fail");
		return -1;
	}
	sprintf(buf,"%d",gpio);
	write(fd,buf,strlen(buf));
	close(fd);

	sprintf(filename,"/sys/class/gpio/gpio%d/value",gpio);
	fd = open(filename,O_RDONLY);
	if (fd < 0)
	{
		ALOGD("open %s fail",filename);
		return -1;
	}

	memset(buf,0,sizeof(buf));
	read(fd,buf,sizeof(buf));
	close(fd);

	value = atoi(buf);

	fd = open("/sys/class/gpio/unexport",O_WRONLY);
	if (fd < 0)
	{
		ALOGD("open /sys/class/gpio/unexport fail");
		return -1;
	}

	memset(buf,0,sizeof(buf));
	sprintf(buf,"%d",gpio);
	write(fd,buf,strlen(buf));
	close(fd);

	return value;
}

(2)设置指定GPIO Pin的方向和值

int setGPIOValue(int gpio,char *direction,int value)
{
	char filename[256] = {0};
	char buf[8] = {0};
	int fd = -1;

	if (access("/sys/class/gpio/export",F_OK))
	{
		ALOGD("/sys/class/gpio/export is no exist");
		return -1;
	}

	if (access("/sys/class/gpio/unexport",F_OK))
	{
		ALOGD("/sys/class/gpio/unexport is no exist");
		return -1;
	}

	fd = open("/sys/class/gpio/export",O_WRONLY);
	if (fd < 0)
	{
		ALOGD("open /sys/class/gpio/export fail");
		return -1;
	}
	sprintf(buf,"%d",gpio);
	write(fd,buf,strlen(buf));
	close(fd);

	memset(filename,0,sizeof(filename));
	memset(buf,0,sizeof(buf));
	sprintf(filename,"/sys/class/gpio/gpio%d/direction",gpio); 
	fd = open(filename,O_WRONLY);
	if (fd < 0)
	{
		ALOGD("open %s fail",filename);
		return -1;
	}

	memset(buf,0,sizeof(buf));
	sprintf(buf,"%s",direction);
	write(fd,buf,sizeof(buf));
	close(fd);
	
	memset(filename,0,sizeof(filename));
	memset(buf,0,sizeof(buf));
	sprintf(filename,"/sys/class/gpio/gpio%d/value",gpio);
	if(access(filename, F_OK))
	{
		ALOGD("%s is no exist!\n", filename);
		return -1;
	}

	memset(buf,0,sizeof(buf));
	sprintf(buf, "%d", value);
	fd = open(filename,O_WRONLY);
	if (fd < 0)
	{
		ACTUILOG("open %s fail", filename);
		return -1;
	}
	write(fd,buf,sizeof(buf));
	close(fd);
	fd = -1;

	return 0;
}

比如setGPIOValue(76,"out",1);  //将GPIO76 设置为输出,并且输出高电平

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux GPIO子系统是一个用于控制嵌入式系统中通用输入/输出(GPIO)的软件子系统。它提供了一种标准的接口,使得应用程序可以通过文件系统接口来访问GPIO。这个子系统可以用于控制各种设备,例如LED、按钮、传感器等等。如果你需要更多的信息,可以查看Linux内核文档。 ### 回答2: Linux GPIO子系统是一种用于管理通用输入输出(GPIO)引脚的软件层。GPIO引脚是一种通用可编程引脚,可以在嵌入式系统中用来通过读取输入或设置输出与外部设备进行通信。 Linux GPIO子系统负责将底层硬件 GPIO 引脚的操作抽象为文件系统的接口,使开发者可以通过读写文件的方式来访问和控制 GPIO 引脚。通过该子系统,可以实现对 GPIO 引脚的配置、读取和写入等操作,以满足不同应用下对 GPIO 的需求。 Linux GPIO子系统的核心是GPIO驱动程序,它与底层硬件层进行交互,完成对GPIO引脚的操作。驱动程序将GPIO引脚映射到内存,通过读写该内存地址即可对引脚进行操作。用户通过访问特定目录下的文件来和引脚进行交互,例如将引脚配置为输入模式、输出模式,以及读取或写入引脚的状态。 通过Linux GPIO子系统,开发者可以方便地进行GPIO引脚的控制。可以根据不同的应用需求,灵活配置引脚的输入输出模式,监听引脚上的状态变化,并根据需要对其他外设进行控制。 总之,Linux GPIO子系统为开发者提供了便捷的接口,使得在嵌入式系统中使用GPIO引脚更加简单和灵活。它允许开发者通过读写文件的方式访问和控制GPIO引脚,满足各种不同嵌入式应用对GPIO的需求。 ### 回答3: LinuxGPIO(General Purpose Input/Output)子系统是通过软件对硬件上的通用输入/输出引脚进行控制的一种机制。它使得开发者可以利用这些GPIO引脚实现各种功能,比如控制LED灯、读取外部传感器的数据等。 LinuxGPIO子系统提供了许多功能和接口来管理和操作GPIO。首先,它使用sysfs文件系统来组织GPIO资源的目录树,并通过文件的方式来读取和写入GPIO的状态。在/sys/class/gpio目录下,每个GPIO引脚都会有一个对应的目录,在该目录中的文件可以用于配置GPIO的方向(输入或输出)、读取和写入GPIO的电平状态。开发者可以使用命令行工具或者编程语言(如Python、C等)来操作这些文件,从而控制GPIO引脚的行为。 其次,LinuxGPIO子系统还提供了设备树(Device Tree)来描述硬件平台上的GPIO资源。设备树是一种描述硬件的数据结构,在启动时通过设备树绑定机制将设备树中定义的GPIO资源与内核驱动程序关联起来。这样,开发者就可以通过调用相应的驱动程序来控制GPIO引脚,而不需要手动操作sysfs文件系统。 此外,LinuxGPIO子系统还支持中断机制,可以让GPIO引脚在特定事件发生时触发中断。通过注册中断处理函数,开发者可以实现对GPIO输入信号的快速响应,提高系统的实时性。 总之,LinuxGPIO子系统为开发者提供了一种方便且灵活的方式来控制硬件上的GPIO引脚。通过sysfs文件系统或设备树,开发者可以轻松地配置、读取和控制GPIO的状态,从而实现各种功能和应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值