2005-04-17 02:20:36 +04:00
/*
2005-05-20 22:33:25 +04:00
* w1 . h
2005-04-17 02:20:36 +04:00
*
* Copyright ( c ) 2004 Evgeniy Polyakov < johnpol @ 2 ka . mipt . ru >
2005-05-20 22:33:25 +04:00
*
2005-04-17 02:20:36 +04:00
*
* This program 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 2 of the License , or
* ( at your option ) any later version .
*
* This program 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 this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
# ifndef __W1_H
# define __W1_H
struct w1_reg_num
{
# if defined(__LITTLE_ENDIAN_BITFIELD)
2005-06-04 01:30:43 +04:00
__u64 family : 8 ,
id : 48 ,
crc : 8 ;
2005-04-17 02:20:36 +04:00
# elif defined(__BIG_ENDIAN_BITFIELD)
__u64 crc : 8 ,
id : 48 ,
family : 8 ;
# else
# error "Please fix <asm / byteorder.h>"
# endif
} ;
# ifdef __KERNEL__
# include <linux/completion.h>
# include <linux/device.h>
2006-04-03 12:04:27 +04:00
# include <linux/mutex.h>
2005-04-17 02:20:36 +04:00
# include "w1_family.h"
# define W1_MAXNAMELEN 32
# define W1_SEARCH 0xF0
2006-03-23 19:11:58 +03:00
# define W1_ALARM_SEARCH 0xEC
2005-04-17 02:20:36 +04:00
# define W1_CONVERT_TEMP 0x44
# define W1_SKIP_ROM 0xCC
# define W1_READ_SCRATCHPAD 0xBE
# define W1_READ_ROM 0x33
# define W1_READ_PSUPPLY 0xB4
# define W1_MATCH_ROM 0x55
2006-03-23 19:11:58 +03:00
# define W1_SLAVE_ACTIVE 0
2005-04-17 02:20:36 +04:00
struct w1_slave
{
struct module * owner ;
unsigned char name [ W1_MAXNAMELEN ] ;
struct list_head w1_slave_entry ;
struct w1_reg_num reg_num ;
atomic_t refcnt ;
u8 rom [ 9 ] ;
u32 flags ;
int ttl ;
struct w1_master * master ;
2005-05-20 22:33:25 +04:00
struct w1_family * family ;
2005-08-17 15:19:08 +04:00
void * family_data ;
2005-05-20 22:33:25 +04:00
struct device dev ;
2005-08-11 17:27:50 +04:00
struct completion released ;
2005-04-17 02:20:36 +04:00
} ;
2008-10-16 09:04:38 +04:00
typedef void ( * w1_slave_found_callback ) ( struct w1_master * , u64 ) ;
2005-04-17 02:20:36 +04:00
2005-06-04 01:30:43 +04:00
/**
* Note : read_bit and write_bit are very low level functions and should only
* be used with hardware that doesn ' t really support 1 - wire operations ,
* like a parallel / serial port .
* Either define read_bit and write_bit OR define , at minimum , touch_bit and
* reset_bus .
*/
2005-04-17 02:20:36 +04:00
struct w1_bus_master
{
2005-06-04 01:30:43 +04:00
/** the first parameter in all the functions below */
2005-12-06 13:38:27 +03:00
void * data ;
2005-06-04 01:30:43 +04:00
/**
* Sample the line level
* @ return the level read ( 0 or 1 )
*/
2005-12-06 13:38:27 +03:00
u8 ( * read_bit ) ( void * ) ;
2005-06-04 01:30:43 +04:00
/** Sets the line level */
2005-12-06 13:38:27 +03:00
void ( * write_bit ) ( void * , u8 ) ;
2005-06-04 01:30:43 +04:00
/**
* touch_bit is the lowest - level function for devices that really
* support the 1 - wire protocol .
* touch_bit ( 0 ) = write - 0 cycle
* touch_bit ( 1 ) = write - 1 / read cycle
* @ return the bit read ( 0 or 1 )
*/
2005-12-06 13:38:27 +03:00
u8 ( * touch_bit ) ( void * , u8 ) ;
2005-06-04 01:30:43 +04:00
/**
* Reads a bytes . Same as 8 touch_bit ( 1 ) calls .
* @ return the byte read
*/
2005-12-06 13:38:27 +03:00
u8 ( * read_byte ) ( void * ) ;
2005-06-04 01:30:43 +04:00
/**
* Writes a byte . Same as 8 touch_bit ( x ) calls .
*/
2005-12-06 13:38:27 +03:00
void ( * write_byte ) ( void * , u8 ) ;
2005-06-04 01:30:43 +04:00
/**
* Same as a series of read_byte ( ) calls
* @ return the number of bytes read
*/
2005-12-06 13:38:27 +03:00
u8 ( * read_block ) ( void * , u8 * , int ) ;
2005-06-04 01:30:43 +04:00
/** Same as a series of write_byte() calls */
2005-12-06 13:38:27 +03:00
void ( * write_block ) ( void * , const u8 * , int ) ;
2005-06-04 01:30:43 +04:00
/**
* Combines two reads and a smart write for ROM searches
* @ return bit0 = Id bit1 = comp_id bit2 = dir_taken
*/
2005-12-06 13:38:27 +03:00
u8 ( * triplet ) ( void * , u8 ) ;
2005-06-04 01:30:43 +04:00
/**
* long write - 0 with a read for the presence pulse detection
* @ return - 1 = Error , 0 = Device present , 1 = No device present
*/
2005-12-06 13:38:27 +03:00
u8 ( * reset_bus ) ( void * ) ;
2005-06-04 01:30:43 +04:00
2008-10-16 09:04:42 +04:00
/**
* Put out a strong pull - up pulse of the specified duration .
* @ return - 1 = Error , 0 = completed
*/
u8 ( * set_pullup ) ( void * , int ) ;
2008-10-16 09:04:38 +04:00
/** Really nice hardware can handles the different types of ROM search
* w1_master * is passed to the slave found callback .
*/
void ( * search ) ( void * , struct w1_master * ,
u8 , w1_slave_found_callback ) ;
2005-04-17 02:20:36 +04:00
} ;
struct w1_master
{
struct list_head w1_master_entry ;
struct module * owner ;
unsigned char name [ W1_MAXNAMELEN ] ;
struct list_head slist ;
int max_slave_count , slave_count ;
unsigned long attempts ;
int slave_ttl ;
int initialized ;
u32 id ;
2005-06-04 01:31:02 +04:00
int search_count ;
2005-04-17 02:20:36 +04:00
atomic_t refcnt ;
void * priv ;
int priv_size ;
2008-10-16 09:04:42 +04:00
/** 5V strong pullup enabled flag, 1 enabled, zero disabled. */
int enable_pullup ;
/** 5V strong pullup duration in milliseconds, zero disabled. */
int pullup_duration ;
2006-02-20 11:15:37 +03:00
struct task_struct * thread ;
2006-04-03 12:04:27 +04:00
struct mutex mutex ;
2005-04-17 02:20:36 +04:00
struct device_driver * driver ;
2005-05-20 22:33:25 +04:00
struct device dev ;
2005-04-17 02:20:36 +04:00
struct w1_bus_master * bus_master ;
2006-03-23 19:11:58 +03:00
u32 seq ;
2005-04-17 02:20:36 +04:00
} ;
int w1_create_master_attributes ( struct w1_master * ) ;
2008-10-16 09:04:38 +04:00
void w1_destroy_master_attributes ( struct w1_master * master ) ;
2006-03-23 19:11:58 +03:00
void w1_search ( struct w1_master * dev , u8 search_type , w1_slave_found_callback cb ) ;
void w1_search_devices ( struct w1_master * dev , u8 search_type , w1_slave_found_callback cb ) ;
struct w1_slave * w1_search_slave ( struct w1_reg_num * id ) ;
void w1_search_process ( struct w1_master * dev , u8 search_type ) ;
struct w1_master * w1_search_master_id ( u32 id ) ;
2008-10-16 09:04:38 +04:00
/* Disconnect and reconnect devices in the given family. Used for finding
* unclaimed devices after a family has been registered or releasing devices
* after a family has been unregistered . Set attach to 1 when a new family
* has just been registered , to 0 when it has been unregistered .
*/
void w1_reconnect_slaves ( struct w1_family * f , int attach ) ;
void w1_slave_detach ( struct w1_slave * sl ) ;
2006-03-23 19:11:58 +03:00
u8 w1_triplet ( struct w1_master * dev , int bdir ) ;
void w1_write_8 ( struct w1_master * , u8 ) ;
2008-11-13 00:27:08 +03:00
u8 w1_read_8 ( struct w1_master * ) ;
2006-03-23 19:11:58 +03:00
int w1_reset_bus ( struct w1_master * ) ;
u8 w1_calc_crc8 ( u8 * , int ) ;
void w1_write_block ( struct w1_master * , const u8 * , int ) ;
2009-01-08 05:09:01 +03:00
void w1_touch_block ( struct w1_master * , u8 * , int ) ;
2006-03-23 19:11:58 +03:00
u8 w1_read_block ( struct w1_master * , u8 * , int ) ;
int w1_reset_select_slave ( struct w1_slave * sl ) ;
2008-10-16 09:04:42 +04:00
void w1_next_pullup ( struct w1_master * , int ) ;
2005-04-17 02:20:36 +04:00
2005-08-11 17:27:49 +04:00
static inline struct w1_slave * dev_to_w1_slave ( struct device * dev )
{
return container_of ( dev , struct w1_slave , dev ) ;
}
static inline struct w1_slave * kobj_to_w1_slave ( struct kobject * kobj )
{
return dev_to_w1_slave ( container_of ( kobj , struct device , kobj ) ) ;
}
static inline struct w1_master * dev_to_w1_master ( struct device * dev )
{
return container_of ( dev , struct w1_master , dev ) ;
}
2006-04-04 20:35:22 +04:00
extern struct device_driver w1_master_driver ;
extern struct device w1_master_device ;
extern int w1_max_slave_count ;
extern int w1_max_slave_ttl ;
extern struct list_head w1_masters ;
extern struct mutex w1_mlock ;
extern int w1_process ( void * ) ;
2005-04-17 02:20:36 +04:00
# endif /* __KERNEL__ */
# endif /* __W1_H */