imx6q内核之信号量

2024-06-12 14:32
文章标签 信号量 内核 imx6q

本文主要是介绍imx6q内核之信号量,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

生气驱动代码

/*************************************************************************> File Name: led_drv.c> Author: XXDK> Email: v.manstein@qq.com > Created Time: Sat 18 Mar 2017 06:27:26 AM PDT************************************************************************/#include<linux/init.h>
#include<linux/module.h>
#include<linux/fs.h>
#include<linux/cdev.h>
#include<linux/device.h>
#include<linux/slab.h>
#include<asm/gpio.h>
#include<mach/iomux-mx6q.h>#define SABRESD_GPIO_LED4	IMX_GPIO_NR(3, 21)struct led{char name[10];int gpio;int data;int open_cnt;struct semaphore sema;dev_t led_dev_id;struct cdev led_cdev;struct class* led_cls;struct file_operations led_fops;
}*sabre_led = NULL;static int led_open(struct inode* inodp, struct file* filp)
{// 获取信息量, 正常获取立刻返回,如果没有获取信息量,进程// 在此进入等待队列休眠,唤醒有两种方式:// 1. 正常获取信号量,函数返回0// 2. 收到信号引起的唤醒,返回非0if(down_interruptible(&sabre_led->sema)) {printk("wake up by signal\n");return -EINTR;}printk("opening sabre led......\n");gpio_set_value(sabre_led->gpio, 1);return 0;
}static int led_close(struct inode* inodp, struct file* filp)
{printk("closing sabre led device\n");up(&sabre_led->sema); // 唤醒等待队列的休眠进程,释放信号量gpio_set_value(sabre_led->gpio, 0);return 0;
}static int led_init(void)
{sabre_led = (struct led*)kmalloc(sizeof(struct led), GFP_KERNEL);if(NULL == sabre_led) {printk("kmalloc error\n");return -1;}sabre_led->led_fops.owner = THIS_MODULE,sabre_led->led_fops.open = led_open,sabre_led->led_fops.release = led_close;sabre_led->gpio = SABRESD_GPIO_LED4;strcpy(sabre_led->name, "led");gpio_request(sabre_led->gpio, sabre_led->name);gpio_direction_output(sabre_led->gpio, 0);// 1. 申请设备号alloc_chrdev_region(&sabre_led->led_dev_id, 0, 1, "leds");// 2. 初始化字符设备对象cdev_init(&sabre_led->led_cdev, &sabre_led->led_fops);// 3. 添加字符设备对象到内核cdev_add(&sabre_led->led_cdev, sabre_led->led_dev_id, 1);// 4. 自动创建设备文件sabre_led->led_cls = class_create(THIS_MODULE, "xxdk");device_create(sabre_led->led_cls, NULL, sabre_led->led_dev_id, NULL, "sabre_led");// 初始化信号量为互斥信号量sema_init(&sabre_led->sema, 1);	return 0;
}static void led_exit(void)
{gpio_set_value(sabre_led->gpio, 0);gpio_free(sabre_led->gpio);device_destroy(sabre_led->led_cls, sabre_led->led_dev_id);class_destroy(sabre_led->led_cls);cdev_del(&sabre_led->led_cdev);unregister_chrdev_region(sabre_led->led_dev_id, 1);kfree(sabre_led);sabre_led = NULL;printk("bye bye\n");return;
}module_init(led_init);
module_exit(led_exit);
MODULE_LICENSE("GPL");
生气测试代码

/*************************************************************************> File Name: led_test.c> Author: XXDK> Email: v.manstein@qq.com > Created Time: Sat 18 Mar 2017 08:24:16 AM PDT************************************************************************/#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>int main()
{int fd;if((fd = open("/dev/sabre_led", O_RDWR)) < 0) {perror("open sabreled failed");}sleep(20);close(fd);return 0;
}



这篇关于imx6q内核之信号量的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1054480

相关文章

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

笔记整理—内核!启动!—kernel部分(2)从汇编阶段到start_kernel

kernel起始与ENTRY(stext),和uboot一样,都是从汇编阶段开始的,因为对于kernel而言,还没进行栈的维护,所以无法使用c语言。_HEAD定义了后面代码属于段名为.head .text的段。         内核起始部分代码被解压代码调用,前面关于uboot的文章中有提到过(eg:zImage)。uboot启动是无条件的,只要代码的位置对,上电就工作,kern

Ubuntu22.04回退系统内核

文章目录 起因回退操作卸载内核禁止内核升级 起因 最近因为系统内核自动升级,导致显卡驱动检测不到,炼丹环境被破坏。无奈只能重装驱动,于是跟着手册操作发现驱动要求的是内核版本是5.15.0-25-generic,而我通过uname -r发现这时候的内核版本是6.8.0-40-generic,看来只能回退了。 我搜索了网上很多的文章,没有一篇文章能够完全解决这个问题,所以在我多次尝

跟我一起玩《linux内核设计的艺术》第1章(四)——from setup.s to head.s,这回一定让main滚出来!(已解封)

看到书上1.3的大标题,以为马上就要见着main了,其实啊,还早着呢,光看setup.s和head.s的代码量就知道,跟bootsect.s没有可比性,真多……这确实需要包括我在内的大家多一些耐心,相信见着main后,大家的信心和干劲会上一个台阶,加油! 既然上篇已经玩转gdb,接下来的讲解肯定是边调试边分析书上的内容,纯理论讲解其实我并不在行。 setup.s: 目标:争取把setup.

编译linux内核出现 arm-eabi-gcc: error: : No such file or directory

external/e2fsprogs/lib/ext2fs/tdb.c:673:29: warning: comparison between : In function 'max2165_set_params': -。。。。。。。。。。。。。。。。。。 。。。。。。。。。。。。。 。。。。。。。。 host asm: libdvm <= dalvik/vm/mterp/out/Inte

linux 内核提权总结(demo+exp分析) -- 任意读写(四)

hijack_modprobe_path篇 本文转自网络文章,内容均为非盈利,版权归原作者所有。 转载此文章仅为个人收藏,分享知识,如有侵权,马上删除。 原文作者:jmpcall 专栏地址:https://zhuanlan.kanxue.com/user-815036.htm     原理同hijack_prctl, 当用户执行错误格式的elf文件时内核调用call_usermod

linux 内核提权总结(demo+exp分析) -- 任意读写(三)

hijack_prctl篇 本文转自网络文章,内容均为非盈利,版权归原作者所有。 转载此文章仅为个人收藏,分享知识,如有侵权,马上删除。 原文作者:jmpcall 专栏地址:https://zhuanlan.kanxue.com/user-815036.htm   prctl函数: 用户态函数,可用于定制进程参数,非常适合和内核进行交互 用户态执行prctl函数后触发prctl系统

linux 内核提权总结(demo+exp分析) -- 任意读写(二)

hijack_vdso篇 本文转自网络文章,内容均为非盈利,版权归原作者所有。 转载此文章仅为个人收藏,分享知识,如有侵权,马上删除。 原文作者:jmpcall 专栏地址:https://zhuanlan.kanxue.com/user-815036.htm     vdso: 内核实现的一个动态库,存在于内核,然后映射到用户态空间,可由用户态直接调用 内核中的vdso如果被修改

linux 内核提权总结(demo+exp分析) -- 任意读写(一)

cred篇 本文转自网络文章,内容均为非盈利,版权归原作者所有。 转载此文章仅为个人收藏,分享知识,如有侵权,马上删除。 原文作者:jmpcall 专栏地址:https://zhuanlan.kanxue.com/user-815036.htm   每个线程在内核中都对应一个线程结构块thread_infothread_info中存在task_struct类型结构体 struct t