Linux内核驱动---配置GPIO

配置GPIO流程:

与在STM32中配置流程一样,每个步骤都有相同的对应函数

申请GPIO:gpio_request()

int gpio_request(unsigned gpio, const char *label);
gpio: 要请求的 GPIO 编号。
label: 用于描述 GPIO 资源的字符串标签。

配置GPIO方向:gpio_direction_output (输出)、gpio_direction_input (输入)

int gpio_direction_output(unsigned gpio, int value);
gpio: 要配置的 GPIO 号码。
value: 输出的初始值,0 表示低电平,非零值表示高电平。

int gpio_direction_input(unsigned int gpio);

读取输入状态:gpio_get_value

int gpio_get_value(unsigned int gpio);
函数返回 GPIO 的状态,0 表示低电平,非零值表示高电平。

设置输出状态:gpio_set_value

void gpio_set_value(unsigned int gpio, int value);
value:要设置的状态,0 表示低电平,非零值表示高电平。

释放 GPIO:gpio_free()

void gpio_free(unsigned int gpio);

Linux内核GPIO大体框架

下面这个代码不可以直接运行,不过大体框架是这样的。要注意的是,不能直接在open、read、write、close直接用mdelay、udelay等延时操作,否则会卡死,如果要用,则在自己写的其他函数中使用,然后在open等函数中调用

#define DEV_NAME "dht"

#define GPIO_DHT11 S3C2410_GPF(6)

static inline void dht_init(void)
{
    gpio_request(GPIO_DHT11,"gpio_dht11");
    gpio_direction_output(GPIO_DHT11,1);
}

static inline void dht11_deinit(void)
{
    gpio_free(GPIO_DHT11);
}

void dht11_start(void)
{
        gpio_direction_output(GPIO_DHT11, 1);
        gpio_set_value(GPIO_DHT11, 0);
        gpio_direction_input(GPIO_DHT11);
}

int wait_respond(void)
{
        gpio_get_value(GPIO_DHT11)
        return 0;
}
static int open(struct inode *node, struct file *file)
{
    printk("kernel open \n");
    return 0;
}

static ssize_t read(struct file *file, char __user *buf, size_t len, loff_t *loff)
{
    dht112_init();
    dht11_start();
    wait_respond();
    copy_to_user(buf,data,sizeof(data));

    printk("kernel read \n");
    return 0;
}

static ssize_t write(struct file *file, const char __user *buf, size_t len, loff_t *loff)
{
    printk("kernel write \n");
    return 0;
}

static int close(struct inode *node, struct file *file)
{
    dht11_deinit();
    printk("kernel close \n");
    return 0;
}

static struct file_operations fops =
{
    .owner = THIS_MODULE,
    .open = open,
    .read = read,
    .write = write,
    .release = close,
};

static struct miscdevice misc_d = 
{
    .minor = MISC_DYNAMIC_MINOR,
    .name = DEV_NAME,
    .fops = &fops
};


static int __init dht11_init(void)
{
    int ret = misc_register(&misc_d);
    if(ret < 0)
        goto err_misc_register_failed;

    printk("dht11_init ------###############################\n");
    return 0;

err_misc_register_failed:
    printk("misc_register failed \n");
    misc_deregister(&misc_d);
    return ret;

}

static void __exit dht11_exit(void)
{
    misc_deregister(&misc_d);
    printk("dht11_exit ... \n");
}

module_init(dht11_init);
module_exit(dht11_exit);
MODULE_LICENSE("GPL");

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
PWM-GPIO驱动程序是Linux内核中的一个驱动模块,用于控制嵌入式系统中的GPIO引脚产生PWM信号。该驱动程序允许开发人员通过编程的方式来控制GPIO引脚的电平变化,从而产生不同占空比的PWM信号。 在Linux内核中,PWM-GPIO驱动程序通过向用户空间提供了相应的接口来实现PWM信号的控制。开发人员可以通过打开相应的设备节点,并使用相应的系统调用函数来设置PWM的频率、占空比等参数,从而实现对GPIO引脚的PWM信号的控制。 驱动程序的核心部分是一个PWM子系统,它与GPIO子系统紧密集成。PWM子系统负责管理PWM信号的生成和控制,而GPIO子系统负责管理GPIO引脚的配置和操作。PWM-GPIO驱动程序在这两个子系统之间起着桥梁的作用。 PWM-GPIO驱动程序的实现方式与硬件平台相关,每个平台可能有不同的具体实现。在驱动程序的初始化过程中,必须先配置GPIO引脚的功能为PWM模式,并将相应的寄存器映射到内核中,以便能够通过对寄存器的操作来控制GPIO引脚。驱动程序还需要初始化PWM子系统,为每个GPIO引脚分配相应的PWM通道,并根据需求设置PWM的频率、占空比等参数。 通过PWM-GPIO驱动程序,开发人员可以方便地利用Linux内核的功能来实现对嵌入式系统中GPIO引脚产生PWM信号的控制。这为开发PWM驱动、控制舵机、LED等应用提供了便捷的方式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Zhaorming.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值