• 驱动点灯


    1. #include <linux/init.h>
    2. #include <linux/module.h>
    3. #include <linux/fs.h>
    4. #include <linux/uaccess.h>
    5. #include <linux/io.h>
    6. #include "head.h"
    7. unsigned int major;
    8. char kbuf[128] = {};
    9. // 定义三个指针指向映射后的虚拟内存
    10. unsigned int *vir_moder_led1;
    11. unsigned int *vir_odr_led1;
    12. unsigned int *vir_rcc;
    13. unsigned int *vir_moder_led2;
    14. unsigned int *vir_odr_led2;
    15. unsigned int *vir_moder_led3;
    16. unsigned int *vir_odr_led3;
    17. // 封装操作方法
    18. int mycdev_open(struct inode *inode, struct file *file)
    19. {
    20. printk("%s:%s:%d\n", __FILE__, __func__, __LINE__);
    21. return 0;
    22. }
    23. ssize_t mycdev_read(struct file *file, char *ubuf, size_t size, loff_t *lof)
    24. {
    25. printk("%s:%s:%d\n", __FILE__, __func__, __LINE__);
    26. int ret;
    27. // 将数据拷贝到用户空间
    28. ret = copy_to_user(ubuf, kbuf, size);
    29. if (ret)
    30. {
    31. printk("copy_to_user filed\n");
    32. return -EIO;
    33. }
    34. return 0;
    35. }
    36. ssize_t mycdev_write(struct file *file, const char *ubuf, size_t size, loff_t *lof)
    37. {
    38. printk("%s:%s:%d\n", __FILE__, __func__, __LINE__);
    39. int ret;
    40. // 将用户空间的数据拷贝到内核空间
    41. ret = copy_from_user(kbuf, ubuf, size);
    42. if (ret)
    43. {
    44. printk("copy_from_user filed\n");
    45. return -EIO;
    46. }
    47. if(kbuf[0] == '0')
    48. {
    49. //关灯逻辑
    50. (*vir_odr_led1) &= (~(0x1 << 10));
    51. (*vir_odr_led2) &= (~(0x1 << 10));
    52. (*vir_odr_led3) &= (~(0x1 << 8));
    53. }
    54. else if(kbuf[0] == '1')
    55. {
    56. //开灯逻辑
    57. (*vir_odr_led1) |= (0x1 << 10);
    58. (*vir_odr_led2) |= (0x1 << 10);
    59. (*vir_odr_led3) |= (0x1 << 8);
    60. }
    61. return 0;
    62. }
    63. int mycdev_close(struct inode *inode, struct file *file)
    64. {
    65. printk("%s:%s:%d\n", __FILE__, __func__, __LINE__);
    66. return 0;
    67. }
    68. // 定义操作方法结构体对象
    69. struct file_operations fops = {
    70. .open = mycdev_open,
    71. .read = mycdev_read,
    72. .write = mycdev_write,
    73. .release = mycdev_close,
    74. };
    75. static int __init mycdev_init(void)
    76. {
    77. // 注册字符设备驱动
    78. major = register_chrdev(0, "mychrdev", &fops);
    79. if (major < 0)
    80. {
    81. printk("字符设备驱动注册失败\n");
    82. return major;
    83. }
    84. printk("注册字符设备驱动成功:major=%d\n", major);
    85. // 进行寄存器的地址映射
    86. vir_moder_led1 = ioremap(PHY_LED1_MODER, 4);
    87. if (vir_moder_led1 == NULL)
    88. {
    89. printk("物理内存地址映射失败%d\n", __LINE__);
    90. return -EFAULT;
    91. }
    92. vir_odr_led1 = ioremap(PHY_LED1_ODR, 4);
    93. if (vir_odr_led1 == NULL)
    94. {
    95. printk("物理内存地址映射失败%d\n", __LINE__);
    96. return -EFAULT;
    97. }
    98. vir_moder_led2 = ioremap(PHY_LED2_MODER, 4);
    99. if (vir_moder_led2 == NULL)
    100. {
    101. printk("物理内存地址映射失败%d\n", __LINE__);
    102. return -EFAULT;
    103. }
    104. vir_odr_led2 = ioremap(PHY_LED2_ODR, 4);
    105. if (vir_odr_led2 == NULL)
    106. {
    107. printk("物理内存地址映射失败%d\n", __LINE__);
    108. return -EFAULT;
    109. }
    110. vir_moder_led3 = ioremap(PHY_LED3_MODER, 4);
    111. if (vir_moder_led3 == NULL)
    112. {
    113. printk("物理内存地址映射失败%d\n", __LINE__);
    114. return -EFAULT;
    115. }
    116. vir_odr_led3 = ioremap(PHY_LED3_ODR, 4);
    117. if (vir_odr_led3 == NULL)
    118. {
    119. printk("物理内存地址映射失败%d\n", __LINE__);
    120. return -EFAULT;
    121. }
    122. vir_rcc = ioremap(PHY_RCC, 4);
    123. if (vir_rcc == NULL)
    124. {
    125. printk("物理内存地址映射失败%d\n", __LINE__);
    126. return -EFAULT;
    127. }
    128. printk("寄存器内存映射成功\n");
    129. // LED1寄存器初始化
    130. (*vir_rcc) |= (0x1 << 4); // GPIOE控制器时钟使能
    131. (*vir_moder_led1) &= (~(0x3 << 20));
    132. (*vir_moder_led1) |= (0x1 << 20);
    133. (*vir_odr_led1) &= (~(0x1 << 10)); // 默认关灯
    134. // LED2寄存器初始化
    135. (*vir_rcc) |= (0x1 << 5); //GPIOF控制器时钟使能
    136. (*vir_moder_led2) &= (~(0x3 << 20));
    137. (*vir_moder_led2) |= (0x1 << 20);
    138. (*vir_odr_led2) &= (~(0x1 << 10)); // 默认关灯
    139. // LED3寄存器初始化
    140. (*vir_moder_led3) &= (~(0x3 << 16));
    141. (*vir_moder_led3) |= (0x1 << 16);
    142. (*vir_odr_led3) &= (~(0x1 << 8)); // 默认关灯
    143. return 0;
    144. }
    145. static void __exit mycdev_exit(void)
    146. {
    147. // 取消内存映射
    148. iounmap(vir_moder_led1);
    149. iounmap(vir_odr_led1);
    150. iounmap(vir_moder_led2);
    151. iounmap(vir_odr_led2);
    152. iounmap(vir_moder_led3);
    153. iounmap(vir_odr_led3);
    154. iounmap(vir_rcc);
    155. // 注销字符设备驱动
    156. unregister_chrdev(major, "mychrdev");
    157. }
    158. module_init(mycdev_init);
    159. module_exit(mycdev_exit);
    160. MODULE_LICENSE("GPL");
    1. #ifndef __HEAD_H__
    2. #define __HEAD_H__
    3. #define PHY_LED1_MODER 0x50006000
    4. #define PHY_LED1_ODR 0x50006014
    5. #define PHY_RCC 0x50000A28
    6. #define PHY_LED2_MODER 0x50007000
    7. #define PHY_LED2_ODR 0x50007014
    8. #define PHY_LED3_MODER 0x50006000
    9. #define PHY_LED3_ODR 0x50006014
    10. #endif
    1. #include <stdio.h>
    2. #include <sys/types.h>
    3. #include <sys/stat.h>
    4. #include <fcntl.h>
    5. #include <unistd.h>
    6. #include <string.h>
    7. int main()
    8. {
    9. char buf[128] = {0};
    10. int fd = open("/dev/mychrdev", O_RDWR);
    11. if (fd < 0)
    12. {
    13. printf("打开设备文件失败\n");
    14. return -1;
    15. }
    16. printf("打开设备文件成功\n");
    17. while (1)
    18. {
    19. printf("请输入进行的操作:0(关灯),1(开灯)>>");
    20. fgets(buf, sizeof(buf), stdin); // 在终端读一个字符串
    21. buf[strlen(buf) - 1] = '\0';
    22. write(fd, buf, sizeof(buf)); // 将数据传递给内核
    23. }
    24. close(fd);
    25. return 0;
    26. }

  • 相关阅读:
    【软件测试】设计优秀的测试用例
    聚观早报 |三星将在印度生产5G设备;马斯克邀请盖茨开特斯拉Semi
    数据结构与算法基础-学习-02-线性表之顺序表-插入元素、删除元素
    [计算机毕业设计]关联挖掘的服装推荐系统
    如何防止商业秘密泄露(洞察眼MIT系统商业机密防泄密解决方案)
    基于PChmi.dll的上位机与PLC1200通讯
    大麦网-演出赛事票务系统画uml图
    软件测试: 测试用例
    【AI 测试】分词器
    科普丨如何让语言芯片保持稳定性能
  • 原文地址:https://blog.csdn.net/weixin_50902363/article/details/133953718