OneWire Library

The OneWire library provides routines for communication via the Dallas OneWire protocol, for example with DS18x20 digital thermometer. OneWire is a Master/Slave protocol, and all communication cabling required is a single wire. OneWire enabled devices should have open collector drivers (with single pull-up resistor) on the shared data line.

Slave devices on the OneWire bus can even get their power supply from data line. For detailed schematic see device datasheet.

Some basic characteristics of this protocol are:

Each OneWire device also has a unique 64-bit registration number (8-bit device type, 48-bit serial number and 8-bit CRC), so multiple slaves can co-exist on the same bus.

  Important :

Library Routines

Ow_Reset

Prototype

function Ow_Reset(var port : byte; pin : byte) : byte;

Returns

  • 0 if the device is present
  • 1 if the device is not present

Description

Issues OneWire reset signal for DS18x20.

Parameters :

  • port: OneWire bus port
  • pin: OneWire bus pin

Requires

Works with Dallas DS1820 temperature sensor only.

Example

To reset the DS1820 that is connected to the RB2 pin:

Ow_Reset(PORTB, 2);

Ow_Read

Prototype

function Ow_Read(var port : byte; pin : byte) : byte;

Returns

Data read from an external device over the OneWire bus.

Description

Reads one byte of data via the OneWire bus.

Parameters :

  • port: OneWire bus port
  • pin: OneWire bus pin

Requires

Works with Dallas DS1820 temperature sensor only.

Example
tmp := Ow_Read(PORTB, 2);

Ow_Write

Prototype

procedure Ow_Write(var port : byte; pin, par : byte);

Returns

Nothing.

Description

Writes one byte of data via the OneWire bus.

Parameters :

  • port: OneWire bus port
  • pin: OneWire bus pin
  • par: data to be written

Requires

Works with Dallas DS1820 temperature sensor only.

Example
Ow_Write(PORTB, 2, 0xCC);

Library Example

This example reads the temperature using DS18x20 connected to pin PORTB.2. After reset, MCU obtains temperature from the sensor and prints it on the Lcd. Make sure to pull-up PORTB.2 line and to turn off the PORTB leds.

Copy Code To ClipboardCopy Code To Clipboard
program OneWire;

// LCD module connections
var LCD_RS : sbit at PORTC2_bit;
var LCD_EN : sbit at PORTC3_bit;
var LCD_D4 : sbit at PORTC4_bit;
var LCD_D5 : sbit at PORTC5_bit;
var LCD_D6 : sbit at PORTC6_bit;
var LCD_D7 : sbit at PORTC7_bit;

var LCD_RS_Direction : sbit at DDC2_bit;
var LCD_EN_Direction : sbit at DDC3_bit;
var LCD_D4_Direction : sbit at DDC4_bit;
var LCD_D5_Direction : sbit at DDC5_bit;
var LCD_D6_Direction : sbit at DDC6_bit;
var LCD_D7_Direction : sbit at DDC7_bit;
// End LCD module connections

//  Set TEMP_RESOLUTION to the corresponding resolution of used DS18x20 sensor:
//  18S20: 9  (default setting; can be 9,10,11,or 12)
//  18B20: 12
const TEMP_RESOLUTION : byte = 9;

var text : array[9] of char;
    temp : word;

procedure Display_Temperature( temp2write : word );
const RES_SHIFT = TEMP_RESOLUTION - 8;

var temp_whole : byte;
    temp_fraction : word;

  begin
    text := '000.0000';
    // check if temperature is negative
    if (temp2write and 0x8000) then
      begin
        text[0] := '-';
        temp2write := not temp2write + 1;
      end;

    // extract temp_whole
    temp_whole := word(temp2write shr RES_SHIFT);

    // convert temp_whole to characters
     if ( temp_whole div 100 ) then
         text[0] := temp_whole div 100  + 48
    else
       text[0] := '0';

    text[1] := (temp_whole div 10)mod 10 + 48;             // Extract tens digit
    text[2] :=  temp_whole mod 10        + 48;             // Extract ones digit

    // extract temp_fraction and convert it to unsigned int
    temp_fraction  :=  word(temp2write shl (4-RES_SHIFT));
    temp_fraction  := temp_fraction and 0x000F;
    temp_fraction  := temp_fraction * 625;

    // convert temp_fraction to characters
    text[4] := word(temp_fraction div 1000)    + 48;         // Extract thousands digit
    text[5] := word((temp_fraction div 100)mod 10 + 48);     // Extract hundreds digit
    text[6] := word((temp_fraction div 10)mod 10  + 48);     // Extract tens digit
    text[7] := word(temp_fraction mod 10)      + 48;         // Extract ones digit

    // print temperature on LCD
    Lcd_Out(2, 5, text);
  end;

begin
  text := '000.0000';
  Lcd_Init();                                    // Initialize LCD
  Lcd_Cmd(_LCD_CLEAR);                           // Clear LCD
  Lcd_Cmd(_LCD_CURSOR_OFF);                      // Turn cursor off
  Lcd_Out(1, 1, ' Temperature:   ');

  Lcd_Chr(2,13,178);                             // Print degree character, 'C' for Centigrades
                                                 // different LCD displays have different char code for degree
  Lcd_Chr(2,14,'C');                             // if you see greek alpha letter try typing 178 instead of 223

  //--- main loop
  while (TRUE) do
    begin
      //--- perform temperature reading
      Ow_Reset(PORTB, 0);                        // Onewire reset signal
      Ow_Write(PORTB, 0, 0xCC);                  // Issue command SKIP_ROM
      Ow_Write(PORTB, 0, 0x44);                  // Issue command CONVERT_T
      Delay_us(120);

      Ow_Reset(PORTB, 0);
      Ow_Write(PORTB, 0, 0xCC);                  // Issue command SKIP_ROM
      Ow_Write(PORTB, 0, 0xBE);                  // Issue command READ_SCRATCHPAD
      Delay_ms(400);

      temp :=  Ow_Read(PORTB, 0);
      temp := (Ow_Read(PORTB, 0) shl 8) + temp;

      //--- Format and display result on Lcd
      Display_Temperature(temp);

      Delay_ms(500);
    end;
end.

HW Connection

Example of DS1820 connection

Example of DS1820 connection

Copyright (c) 2002-2012 mikroElektronika. All rights reserved.
What do you think about this topic ? Send us feedback!
Want more examples and libraries? 
Find them on LibStock - A place for the code