Program to read the temperature from multiple DS18B20 sensors on the same pin. The original library/code came from Petras Saduikis (see http://mbed.org/users/snatch59/programs/OneWireCRC/gpdz56), but I've modified it to remember the address of multiple sensors all connected to the same data pin. My sample program displays the temperature of each device in turn. If you want to see more of what's going on behind the scenes turn on the debug by setting DebugTrace pc(OFF, TO_SERIAL); to ON (instead of OFF) in the couple of places it's used - it will log the device addresses as they are found etc. The addresses are set in the devices at the factory - I don't think they can be changed, the search always seems to find them in the same order, but this won't be anything to do with the way you've plugged them in. I've had a play with up to 7 sensors (the code has a limit of 10 hardwired in it, but this would be easy to change)
DebugTrace.h
- Committer:
- tonymudd
- Date:
- 2011-07-17
- Revision:
- 0:fb8b6da96a8b
File content as of revision 0:fb8b6da96a8b:
/* * DebugTrace. Allows dumping debug messages/values to serial or * to file. * * Copyright (C) <2009> Petras Saduikis <petras@petras.co.uk> * * This file is part of DebugTrace. * * DebugTrace is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * DebugTrace is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with DebugTrace. If not, see <http://www.gnu.org/licenses/>. */ #ifndef SNATCH59_DEBUGTRACE_H #define SNATCH59_DEBUGTRACE_H enum eLog {OFF, ON}; enum eLogTarget {TO_SERIAL, TO_FILE}; class DebugTrace { public: DebugTrace(eLog on, eLogTarget mode, const char* fileName = "log.txt", const int maxSize = 1024); ~DebugTrace(); void clear(); void traceOut(const char* fmt, ...); private: eLog enabled; eLogTarget logMode; int maxFileSize; int currentFileSize; char* logFile; char* logFileBackup; int logFileStatus; // if things go wrong, don't write any more data to file void backupLog(); }; #endif