驱动开发 基于gpio子系统来实现对stm32开发板的led亮灭实现,附加定时器实现一秒亮灭(软件:vscode)

cs 复制代码
#include <linux/init.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/of_gpio.h>
#include <linux/gpio.h>
#include <linux/timer.h>
struct device_node *dnode;
unsigned int gpiono;
unsigned int gpiono2;
unsigned int gpiono3;
// 分配定时器对象
struct timer_list mytimer;
// 设置一个定时器处理函数
void mytimer_func(struct timer_list *timer)
{
    gpio_set_value(gpiono, !gpio_get_value(gpiono));
    gpio_set_value(gpiono2, !gpio_get_value(gpiono2));
    gpio_set_value(gpiono3, !gpio_get_value(gpiono3));
    mod_timer(timer, jiffies + HZ);
}
static int __init mycdev_init(void)
{
    dnode = of_find_node_by_path("/myled");
    if (dnode == NULL)
    {
        printk("解析设备树节点失败\n");
        return -ENXIO;
    }
    printk("解析GPIO信息成功\n");
    // 获取GPIO编号
    gpiono = of_get_named_gpio(dnode, "led1-gpio", 0);
    gpiono2 = of_get_named_gpio(dnode, "led2-gpio", 0);
    gpiono3 = of_get_named_gpio(dnode, "led3-gpio", 0);
    if (gpiono < 0)
    {
        printk("GPIO1编号解析失败\n");
    }
    if (gpiono2 < 0)
    {
        printk("GPIO2编号解析失败\n");
    }
    if (gpiono3 < 0)
    {
        printk("GPIO3编号解析失败\n");
    }
    printk("gpio编号解析成功%d\n", gpiono);
    printk("gpio1编号解析成功%d\n", gpiono2);
    printk("gpio2编号解析成功%d\n", gpiono3);
    // 申请gpio编号
    int ret = gpio_request(gpiono, NULL);
    int ret2 = gpio_request(gpiono2, NULL);
    int ret3 = gpio_request(gpiono3, NULL);
    if (ret)
    {
        printk("申请GPIO1编号失败\n");
        return -1;
    }
    if (ret2)
    {
        printk("申请GPIO2编号失败\n");
        return -1;
    }
    if (ret3)
    {
        printk("申请GPIO3编号失败\n");
        return -1;
    }
    printk("申请gpio1编号成功\n");
    printk("申请gpio2编号成功\n");
    printk("申请gpio3编号成功\n");
    // 初始化定时器对象,定时器对象中的expires需要手动初始化
    timer_setup(&mytimer, mytimer_func, 0);
    mytimer.expires = jiffies + HZ; // HZ是一秒,这里可以直接用数字
     // 注册定时器
    add_timer(&mytimer);
    // 输出gpio管脚,默认输出低电平
    gpio_direction_output(gpiono, 0);
    gpio_direction_output(gpiono2, 0);
    gpio_direction_output(gpiono3, 0);
    // 亮灯
    gpio_set_value(gpiono, 1);
    gpio_set_value(gpiono2, 1);
    gpio_set_value(gpiono3, 1);
    return 0;
}
static void __exit mycdev_exit(void)
{
    gpio_set_value(gpiono, 0);
    gpio_set_value(gpiono2, 0);
    gpio_set_value(gpiono3, 0);
    gpio_free(gpiono);
    gpio_free(gpiono2);
    gpio_free(gpiono3);
    del_timer(&mytimer);
}
module_init(mycdev_init);
module_exit(mycdev_exit);
MODULE_LICENSE("GPL");
相关推荐
Lester_110110 天前
STM32霍尔传感器输入口设置为复用功能输入口时,还能用GPIO函数直接读取IO的状态吗
stm32·单片机·嵌入式硬件·电机控制
LCG元10 天前
低功耗显示方案:STM32L0驱动OLED,动态波形绘制与优化
stm32·嵌入式硬件·信息可视化
z203483152010 天前
STM32F103系列单片机定时器介绍(二)
stm32·单片机·嵌入式硬件
古译汉书10 天前
【IoT死磕系列】Day 7:只传8字节怎么控机械臂?学习工业控制 CANopen 的“对象字典”(附企业级源码)
数据结构·stm32·物联网·http
Alaso_shuang10 天前
STM32 核心输入、输出模式
stm32·单片机·嵌入式硬件
TangDuoduo000510 天前
【Linux SPI驱动开发】
驱动开发
2501_9181269110 天前
stm32死锁是怎么实现的
stm32·单片机·嵌入式硬件·学习·个人开发
z203483152010 天前
STM32F103系列单片机定时器介绍(一)
stm32·单片机
The️10 天前
Linux驱动开发之Read_Write函数
linux·运维·服务器·驱动开发·ubuntu·交互
星马梦缘10 天前
驱动层开发——蜂鸣器驱动
stm32·单片机·嵌入式硬件·hal·驱动