温度传感器不工作

时间:2017-09-20 13:54:33

标签: c embedded embedded-linux sensor raspberry-pi3

Greetins,

我最近买了一个温度&湿度传感器(aosong am2302)。我把它挂在了一个锉刀上,它和adafruit图书馆一样有魅力。当我试图让它在另一块板上工作时(问题here),问题就来了。我使用this library进行gpio阅读。我为gpio映射修改了beaglebone的文件,就是这样。我运行测试,他们工作,所以基本上lib看起来像它的工作原理。所以在那之后,我编码传感器阅读器,它不起作用,我不知道为什么。 运行传感器阅读器后,如果我检查文件系统,则会导出gpio。

传感器的安装方式如下: - 功率为5V(也尝试使用3.3v) -VCC到gpio - 接地GND。

这里是代码

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <stdint.h>
#include <sys/wait.h>
#include <sys/time.h>

#include "libsoc_gpio.h" //library for gpio reading

#define MAXTIMINGS 10
#define SILENT 0 

int bits[MAXTIMINGS+1],data[5];
int readDHT(int pin,int allowRetry);

int
main(int argc, char **argv)
{   int dhtpin;
    if (argc>1)dhtpin=atoi(argv[1]);
    else printf("Introduce pin");

    if( SILENT < 1 ) {
        printf("Using pin #%d\n", dhtpin);
    }
    readDHT(dhtpin,5);
    return 0;
}


int
readDHT(int pin, int allowRetry)
{
    int bitidx=0;
    int counter = 0;
    int i=0,j=0;
    data[0] = data[1] = data[2] = data[3] = data[4] = 0;

    gpio *gpio_output = libsoc_gpio_request(pin, LS_SHARED); //export GPIO

    if (gpio_output == NULL)
    {
        fprintf(stderr, "Failed to open GPIO %d\n", pin);
        return -1;
    }

    libsoc_gpio_set_direction(gpio_output, OUTPUT); 
    if (libsoc_gpio_get_direction(gpio_output) != OUTPUT)
    {
        fprintf(stderr, "Failed to set direction to OUTPUT\n");
        if (gpio_output)
        {
            libsoc_gpio_free(gpio_output);
        }
        return -1;
    }

    libsoc_gpio_set_level(gpio_output, LOW);
    libsoc_gpio_set_level(gpio_output, HIGH);

    libsoc_gpio_set_direction(gpio_output, INPUT);

    /* Wait for pin to drop */
    while (libsoc_gpio_get_level(gpio_output) == HIGH)
    {
        if(counter++>10000){
            printf("ERROR: Pin never dropped\n");
            return 1;
        }
    }
    if (i<= MAXTIMINGS)
    {
        counter =0;
        while (libsoc_gpio_get_level(gpio_output) == LOW){
            if(counter++ == 1000)
                break;
        }
        counter =0;
        while(libsoc_gpio_get_level(gpio_output) == HIGH){
            if (counter++==1000)
                break;
        }
        bits[bitidx++] = counter;
        i++;
    }


    /* read data */
    for (i = 1; i < bitidx; i++) {
        data[j / 8] <<= 1;
        if(bits[i]>200){
            data[j/8] |= 1;
        }
        j++;
    }
    if( SILENT < 1 ) {
        printf("Data (%d): 0x%x 0x%x 0x%x 0x%x 0x%x\n", j, data[0], data[1], data[2], data[3], data[4]);
    }
    if ((j >= 39) && (data[4] == ((data[0] + data[1] + data[2] + data[3]) & 0xFF)) ) {


            float f, h;
            h = data[0] * 256 + data[1];
            h /= 10;

            f = (data[2] & 0x7F)* 256 + data[3];
                f /= 10.0;
                if (data[2] & 0x80)  f *= -1;
            printf("CTemp: %.1f\nFTemp: %.1f\nHum: %.1f%\n", f, ((f*9)/5)+32, h);
        } else if( allowRetry > 0 ) {
            sleep(1);
            if( SILENT < 1 ) {
            printf( "Error getting information. Retrying\n" );
            }
            return readDHT(pin, --allowRetry );
        } else {
            if( SILENT < 1 ) {
            printf( "Error getting information. Retries exhausted.\n" );
            }
            return 1;
        }

        return 0;

    if (gpio_output)
    {
        libsoc_gpio_free(gpio_output);
    }

    /* Check we got all the data and checksum matches */
}

使用此代码,我得到“Pin永不丢弃”,因此pin永远不会变为0,因此它不会报告数据。所以我决定尝试使用bash并查看引脚是否下降到0.我编码与前一个代码相同但在bash中看到引脚的值(始终为1,不丢弃)。到这一步,我用完选项,传感器工作(它没有坏掉),库工作但这台机器上的传感器没有。关于如何寻找解决方案的任何线索或想法?

谢谢:)

1 个答案:

答案 0 :(得分:1)

要尝试的一些事情可能会让你去....

  1. 首先将计数器“counter ++&gt; 10000”增加到更大的值,可能是你正在运行的新处理器以更快的速率递增计数器,你只需在引脚丢失之前超时。

  2. 如果这不起作用,请删除超时计数器并在源中永远循环,同时移除传感器,然后用一根电线将数据线物理地拉到地面,看看你的代码/新处理器是否捕获信号发生变化,至少你知道你的源/硬件配置正确,这样你就可以把精力集中在其他地方了。

  3. 仔细检查新处理器“高”级别与传感器“高”阈值之间的电压兼容性,以确保它在数据线上捕获“1”。

  4. Lettus知道你怎么去!