【树莓派】关于树莓派2代,更新最新内核后,DS18B20温度传感器无法找到对应文件的问题的解决

本文主要是介绍【树莓派】关于树莓派2代,更新最新内核后,DS18B20温度传感器无法找到对应文件的问题的解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、问题和解决方法

问题:

在网上关于DS18B20温度传感器的教程有很多,但大部分都是基于老版本内核的例子。在入手树莓派2代后,加上DS18B20,按照他们的方法就是找不到对应的28-****文件,在经过几天研究实验,以及查阅相关资料后。发现官方给出的说法是:升级新内核之后,防止gpio冲突,使用了新的dt策略。然后问题就来了。

解决方法:

在/boot/config.txt配置文件的最后添加如下内容: dtoverlay=w1-gpio-pullup,gpiopin=4

然后按照正常的流程就可以看到那个期待已久的28-****文件了

 

二、实验操作

 


1、材料:

树莓派开发板(我的是2代RS版本),DS18B20传感器(我的是论坛淘宝店,板载已添加上拉电阻的那个),杜邦线若干,足额5V电源,内存卡,扩展板(可选),面包板(可选),排线(可选)

2、接线:

      VCC 接  3.3V 的gpio接口

      GND 接  GND 的gpio接口

      DQ  接   GPIO7(#4)的gpio接口

3、然后采用VNC Viewer登陆,

4、温度操作

(1)、首先升级内核(可忽略,但如果版本较老,可能影响设备读取)

1

2

apt-get update

apt-get upgrade

(2)、确认设备是否生效

1

2

3

4

sudomodprobe w1-gpio

sudomodprobe w1-therm

cd/sys/bus/w1/devices/

ls

       显示结果:

1

2

3

pi@raspberrypi:~$ cd /sys/bus/w1/devices/

pi@raspberrypi:/sys/bus/w1/devices$ ls

28-00000494cb79 w1_bus_master1

       28-00000494cb79就是笔者外接的温度传感器设备,但并不是每个客户端都显示一样的,这个是传感器的序列号。

(3)、查看当前温度

1

2

cd28-00000494cb79

catw1_slave

       显示结果:

1

2

70 01 4b 46 7f ff 10 10 e1 : crc=e1 YES

70 01 4b 46 7f ff 10 10 e1 t=23000

       第二行的t=23000就是当前的温度值,要换算成摄氏度,除以1000,即当前温度为23000/1000=23摄氏度。

(4)、接下来就可以编程读出该温度了:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <errno.h>
#include <stdlib.h>
#include <stdio.h>#define  BUFSIZE  128int main(void)
{float temp;int i, j;<span style="white-space:pre">	</span>int fd;int ret;char buf[BUFSIZE];char tempBuf[5];fd = open("/sys/bus/w1/devices/28-00000494cb79/w1_slave", O_RDONLY); //以只读方式打开ds18b20设备文件if(-1 == fd){       				   //打开设备文件出错perror("open device file error");   		  //打印出错信息(原因)return 1;}while(1){ret = read(fd, buf, BUFSIZE);  		   //将设备文件中的内容读入buf中if(0 == ret){                                   //返回0表示读文件结束break;	                              //跳出循环体}if(-1 == ret){              		   //读文件出错if(errno == EINTR){                    //出错是由中断引起的continue;	             	  //继续读文件}perror("read()");       	           //打印出错信息(原因)close(fd);                   	  //关闭文件return 1;}}for(i=0;i<sizeof(buf);i++){if(buf[i] == 't'){                 		 //如果读到‘t’,说明后面马上出现温度值for(j=0;j<sizeof(tempBuf);j++){tempBuf[j] = buf[i+2+j];    //将温度值以字符串的形式写入tempBuf中}}	}temp = (float)atoi(tempBuf) / 1000; 		 //将字符串转换为浮点型温度数据printf("%.3f C\n",temp);  			 //打印出温度值close(fd); 				//关闭文件return 0;
}

 

5、然后就可以上传到yeelink上,或者做个微信公众平台,控制获取温度。

 


—— 2018-08-05 ——

这篇关于【树莓派】关于树莓派2代,更新最新内核后,DS18B20温度传感器无法找到对应文件的问题的解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用