Как читать темп с DS18B20 с помощью платы UART

0

Я купил такую плату Изображение 174551, теперь я хочу подключить датчик температуры к этой плате. Как читать температуру от датчика в c или c++? Я попытался написать код, но он не сработает. Я подключаю DS18B20 data cabel непосредственно к контактам TXD и RXD.

#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <unistd.h>
#include <fcntl.h>
#include <termios.h>
#include <cstring>
#include <inttypes.h>
#include <errno.h>

int
set_interface_attribs (int fd, int speed, int parity)
{
    struct termios tty;
    memset (&tty, 0, sizeof tty);
    if (tcgetattr (fd, &tty) != 0)
    {
            std::cout<<"error "<<errno<<" from tcgetattr";
            return -1;
    }

    cfsetospeed (&tty, speed);
    cfsetispeed (&tty, speed);

    tty.c_cflag = (tty.c_cflag & ~CSIZE) | CS8;     // 8-bit chars
    // disable IGNBRK for mismatched speed tests; otherwise receive break
    // as \000 chars
    tty.c_iflag &= ~IGNBRK;         // ignore break signal
    tty.c_lflag = 0;                // no signaling chars, no echo,
                                    // no canonical processing
    tty.c_oflag = 0;                // no remapping, no delays
    tty.c_cc[VMIN]  = 0;            // read doesn't block
    tty.c_cc[VTIME] = 5;            // 0.5 seconds read timeout

    tty.c_iflag &= ~(IXON | IXOFF | IXANY); // shut off xon/xoff ctrl

    tty.c_cflag |= (CLOCAL | CREAD);// ignore modem controls,
                                    // enable reading
    tty.c_cflag &= ~(PARENB | PARODD);      // shut off parity
    tty.c_cflag |= parity;
    tty.c_cflag &= ~CSTOPB;
    tty.c_cflag &= ~CRTSCTS;

    if (tcsetattr (fd, TCSANOW, &tty) != 0)
    {
        std::cout<<"error "<<errno<<" from tcsetattr";
            return -1;
    }
    return 0;
}

void
set_blocking (int fd, int should_block)
{
    struct termios tty;
    memset (&tty, 0, sizeof tty);
    if (tcgetattr (fd, &tty) != 0)
    {
        std::cout<<"error "<<errno<<" from tggetattr";
            return;
    }
    tty.c_cc[VMIN]  = should_block ? 1 : 0;
    tty.c_cc[VTIME] = 5;            // 0.5 seconds read timeout

    if (tcsetattr (fd, TCSANOW, &tty) != 0)
            std::cout<<"error "<<errno<<" setting term attributes";
}

int main()
{
        char *portname = "/dev/ttyUSB0";
        int tty_fd = open (portname, O_RDWR | O_NOCTTY | O_SYNC);
        if (tty_fd < 0)
        {
            std::cout<<"error "<<errno<<" opening "<<portname<<": "<< strerror (errno);
                return -1;
        }

        set_interface_attribs (tty_fd, B9600, 0);  // set speed to 115,200 bps, 8n1 (no parity)
        set_blocking (tty_fd, true);

        unsigned char c = 0xCC;
        if(!write(tty_fd, &c, sizeof(c)))
            std::cout<<"Write error";

        sleep(2);

        unsigned char buffer[8];
        int size;
        if((size = read(tty_fd, &buffer, 8)) < 0)
                std::cout<<"Error";
        else
            std::cout<<"CC("<<size<<")='"<<buffer<<"'";

        std::cout<<"\n";

        c = 0x44;
        if(!write(tty_fd, &c, sizeof(c)))
            std::cout<<"Write error2";

        c = 0xBE;
        if(!write(tty_fd, &c, sizeof(c)))
            std::cout<<"Write error2";

        sleep(2);

        if((size = read(tty_fd, &buffer, 8)) < 0)
                std::cout<<"Error";
        else
            std::cout<<"BE("<<size<<")='"<<buffer<<"'";

        std::cout<<"\n######################\n";

        close(tty_fd);
}

Я получил:

CC(1)='Č@'
BE(2)='@ž@'
######################
CC(1)='Č@'
BE(2)='@ž@'
######################
CC(1)='Č@'
BE(2)='@ž@'
######################

Вы можете мне помочь?

  • 0
    Две возможные проблемы: Вы уверены, что получаете данные в виде текста ? И если вы это сделаете, вы уверены, что данные обнуляются?
  • 0
    Вы уверены, что используете правильный файл устройства. Если я подключу Arduino UNO. Я должен подключиться к /dev/ttyACM0 .
Показать ещё 2 комментария
Теги:
uart

2 ответа

3

Вы не можете делать это с помощью какого-либо программного обеспечения. DS18B20 электрически несовместим с вашей доской. Датчик использует 1-проводную схему связи с открытым коллектором, которая полностью отличается от последовательного протокола, обычно используемого с этой платой. С большим трудом вы можете сделать некоторые битовые колебания сигналов RTS/CTS, но вам нужна схема, чтобы объединить их в двунаправленный сигнал с открытым коллектором.

  • 0
    Кажется маловероятным Сам чип использует протокол Maxim 1-wire. Разумеется, плата, похоже, разбивает его на сигналы стандартного последовательного порта. В 1-проводном протоколе нет места для RTS и CTS :) И он на самом деле возвращает данные.
  • 0
    Так что использовать эту плату для чтения данных из DS18B20 будет крайне сложно? Как прочитать температуру с датчика на ноутбуке?
Показать ещё 6 комментариев
1

Вы можете взломать UART для связи с 1-проводным протоколом. Подключите Rx к Tx и добавьте 4,7 подтягивающего резистора. См. Примечание к приложению от maxim:

http://www.maximintegrated.com/en/app-notes/index.mvp/id/214

Ещё вопросы

Сообщество Overcoder
Наверх
Меню