当前位置: 首页 > news >正文

23.08.16驱动点灯

#include <linux/init.h>
#include <linux/module.h>
#include <linux/fs.h>
#include <linux/uaccess.h>
#include <linux/io.h>
#include <linux/device.h>
#include "head.h"int major;
char kbuf[128] = {0};//定义指针接收映射成功的虚拟内存首地址
unsigned int *vir_moder;
unsigned int *vir_odr;
unsigned int *vir_rcc;
gpio_t *vir1;
gpio_t *vir2;
gpio_t *vir3;
unsigned int *vir;
struct class *cls;
struct device *dev;
//封装操作方法
int mycdev_open(struct inode *inode, struct file *file)
{printk("%s:%s:%d\n",__FILE__,__func__,__LINE__);return 0;
}
ssize_t mycdev_read(struct file *file, char  *ubuf, size_t size, loff_t *lof)
{printk("%s:%s:%d\n",__FILE__,__func__,__LINE__);int ret;ret=copy_to_user(ubuf,kbuf,size);if(ret){printk("copy_to_user filad\n");return ret;}return 0;
}ssize_t mycdev_write(struct file *file, const char  *ubuf, size_t size, loff_t *lof)
{int ret;ret=copy_from_user(kbuf,ubuf,size);if(ret){printk("copy_from_user filed\n");return ret;}int c=(kbuf[0]-'0')*2+(kbuf[1]-'0');switch(c){case 2:(vir1->ODR)&=(~(0x1<<10));break;case 3:(vir1->ODR) |=(0x1<<10);break;case 4:(vir2->ODR)&=(~(0x1<<10));break;case 5:(vir2->ODR) |=(0x1<<10);break;case 6:(vir3->ODR)&=(~(0x1<<8));break;case 7:(vir3->ODR) |=(0x1<<8);break;default:printk("input error\n");break;        }return 0;}int mycdev_close(struct inode *inode, struct file *file)
{printk("%s:%s:%d\n",__FILE__,__func__,__LINE__);return 0;
}
// 定义操作方法结构体遍历并且初始化
struct file_operations fops = {.open=mycdev_open,.read=mycdev_read,.write=mycdev_write,.release=mycdev_close,
};static int __init mycdev_init(void)
{int i;// 注册字符设备驱动major = register_chrdev(0, "mychrdev", &fops);if(major<0){printk("字符设备驱动注册失败\n");return major;}printk("字符设备驱动注册成功major=%d\n",major);//向上提交目录信息cls = class_create(THIS_MODULE,"mycdev");if (IS_ERR(cls)){printk("向上提交目录信息失败\n");return -PTR_ERR(cls);}printk("向上提交目录信息成功\n");//向上提交设备信息for(i = 0;i < 3; i++){dev = device_create(cls, NULL, MKDEV(major, i), NULL, "mycdev%d", i);if (IS_ERR(dev)){printk("向上提交设备节点信息失败\n");return -PTR_ERR(cls);}}printk("向上提交设备节点成功\n");//完成硬件寄存器物理内存的映射vir=ioremap(RCC_MP_AHB4_ENSETR,4);if(vir==NULL){printk("物理内存映射失败%d\n",__LINE__);return -EFAULT;} vir1=ioremap(GPIOE,sizeof(gpio_t));if(vir1==NULL){printk("物理内存映射失败%d\n",__LINE__);return -EFAULT;}vir2=ioremap(GPIOF,sizeof(gpio_t));if(vir2==NULL){printk("物理内存映射失败%d\n",__LINE__);return -EFAULT;}vir3=ioremap(GPIOE,sizeof(gpio_t));if(vir3==NULL){printk("物理内存映射失败%d\n",__LINE__);return -EFAULT;}printk("物理内存映射成功\n");(vir1->MODER) &= (~(0x3<<20));(vir1->MODER) |= (0x1<<20);(vir2->MODER) &= (~(0x3<<20));(vir2->MODER) |= (0x1<<20);(vir3->MODER) &= (~(0x3<<16));(vir3->MODER) |= (0x1<<16);  (*vir) |= (0x3<<4);(vir1->ODR) &= (~(0x1<<10));(vir2->ODR) &= (~(0x1<<10));(vir3->ODR) &= (~(0x1<<8));return 0;
}
static void __exit mycdev_exit(void)
{iounmap(vir);iounmap(vir1);iounmap(vir2);iounmap(vir3);int i;for(i=0;i<3;i++)device_destroy(cls,MKDEV(major,i));class_destroy(cls);unregister_chrdev(major,"mycdev");}
module_init(mycdev_init);
module_exit(mycdev_exit);
MODULE_LICENSE("GPL");

http://www.lryc.cn/news/126362.html

相关文章:

  • 数据结构——堆
  • 重复学习1:NLP
  • 做海外游戏推广有哪些条件?
  • JavaFx基础学习【五】:FXML布局文件使用
  • 通过Python爬虫提升网站搜索排名
  • 【博客698】为什么当linux作为router使用时,安装docker后流量转发失败
  • el-dialog嵌套,修改内层el-dialog样式(自定义样式)
  • B树和B+树区别
  • intelJ IDEA\PHPStorm \WebStorm\PyCharm 通过ssh连接远程Mysql\Postgresql等数据库
  • vfuhyuuy
  • CSS自学框架之表单
  • 使用Spring Boot和Redis实现用户IP接口限流的详细指南
  • 前端性能优化——包体积压缩插件,打包速度提升插件,提升浏览器响应的速率模式
  • 配置vscode
  • 【Spring】深入理解 Spring 事务及其传播机制
  • eclipse常用设置
  • ajax解析
  • CSS3:图片边框
  • (七)Unity VR项目升级至Vision Pro需要做的工作
  • 【计算机视觉|生成对抗】生成对抗网络(GAN)
  • 神经网络基础-神经网络补充概念-15-神经网络概览
  • iOS Epub阅读器改造记录
  • 负载均衡搭建
  • form表单input标签的23种type类型值?
  • python selenium如何保存网站的cookie用于下次自动登录
  • DHCP Server
  • DMR+PoC宽窄融合互通解决方案
  • Springboot定时执行任务
  • 【Apollo】阿波罗自动驾驶:塑造自动驾驶技术的未来
  • JavaEE初阶:多线程 - Thread 类的基本用法