[PATCH] w1: Adds a sysfs entry (w1_master_search) that allows you to disable/enable...
authorEvgeniy Polyakov <johnpol@2ka.mipt.ru>
Fri, 3 Jun 2005 21:31:02 +0000 (01:31 +0400)
committerGreg Kroah-Hartman <gregkh@suse.de>
Wed, 22 Jun 2005 04:43:11 +0000 (21:43 -0700)
Adds a sysfs entry (w1_master_search) that allows you to disable/enable
periodic searches.

Signed-off-by: Ben Gardner <bgardner@wabtec.com>
Signed-off-by: Evgeniy Polyakov <johnpol@2ka.mipt.ru>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/w1/w1.c
drivers/w1/w1.h
drivers/w1/w1_int.c

index 4fa959f08554ccf82fd4b9ededb7eea53a236e18..48da17596d43bd0bf8f7028f84aabaefe0a646c9 100644 (file)
@@ -148,6 +148,39 @@ static ssize_t w1_master_attribute_show_name(struct device *dev, struct device_a
        return count;
 }
 
+static ssize_t w1_master_attribute_store_search(struct device * dev,
+                                               struct device_attribute *attr,
+                                               const char * buf, size_t count)
+{
+       struct w1_master *md = container_of(dev, struct w1_master, dev);
+
+       if (down_interruptible (&md->mutex))
+               return -EBUSY;
+
+       md->search_count = simple_strtol(buf, NULL, 0);
+
+       up(&md->mutex);
+
+       return count;
+}
+
+static ssize_t w1_master_attribute_show_search(struct device *dev,
+                                              struct device_attribute *attr,
+                                              char *buf)
+{
+       struct w1_master *md = container_of(dev, struct w1_master, dev);
+       ssize_t count;
+
+       if (down_interruptible (&md->mutex))
+               return -EBUSY;
+
+       count = sprintf(buf, "%d\n", md->search_count);
+
+       up(&md->mutex);
+
+       return count;
+}
+
 static ssize_t w1_master_attribute_show_pointer(struct device *dev, struct device_attribute *attr, char *buf)
 {
        struct w1_master *md = container_of(dev, struct w1_master, dev);
@@ -242,6 +275,12 @@ static ssize_t w1_master_attribute_show_slaves(struct device *dev, struct device
                __ATTR(w1_master_##_name, _mode,                \
                       w1_master_attribute_show_##_name, NULL)
 
+#define W1_MASTER_ATTR_RW(_name, _mode)                                \
+       struct device_attribute w1_master_attribute_##_name =   \
+               __ATTR(w1_master_##_name, _mode,                \
+                      w1_master_attribute_show_##_name,        \
+                      w1_master_attribute_store_##_name)
+
 static W1_MASTER_ATTR_RO(name, S_IRUGO);
 static W1_MASTER_ATTR_RO(slaves, S_IRUGO);
 static W1_MASTER_ATTR_RO(slave_count, S_IRUGO);
@@ -249,6 +288,7 @@ static W1_MASTER_ATTR_RO(max_slave_count, S_IRUGO);
 static W1_MASTER_ATTR_RO(attempts, S_IRUGO);
 static W1_MASTER_ATTR_RO(timeout, S_IRUGO);
 static W1_MASTER_ATTR_RO(pointer, S_IRUGO);
+static W1_MASTER_ATTR_RW(search, S_IRUGO | S_IWUGO);
 
 static struct attribute *w1_master_default_attrs[] = {
        &w1_master_attribute_name.attr,
@@ -258,6 +298,7 @@ static struct attribute *w1_master_default_attrs[] = {
        &w1_master_attribute_attempts.attr,
        &w1_master_attribute_timeout.attr,
        &w1_master_attribute_pointer.attr,
+       &w1_master_attribute_search.attr,
        NULL
 };
 
@@ -643,11 +684,14 @@ int w1_process(void *data)
                if (!dev->initialized)
                        continue;
 
+               if (dev->search_count == 0)
+                       continue;
+
                if (down_interruptible(&dev->mutex))
                        continue;
 
                list_for_each_entry(sl, &dev->slist, w1_slave_entry)
-                               clear_bit(W1_SLAVE_ACTIVE, (long *)&sl->flags);
+                       clear_bit(W1_SLAVE_ACTIVE, (long *)&sl->flags);
 
                w1_search_devices(dev, w1_slave_found);
 
@@ -662,6 +706,10 @@ int w1_process(void *data)
                        } else if (test_bit(W1_SLAVE_ACTIVE, (unsigned long *)&sl->flags))
                                sl->ttl = dev->slave_ttl;
                }
+
+               if (dev->search_count > 0)
+                       dev->search_count--;
+
                up(&dev->mutex);
        }
 
index 3cfdd08d32fcf4c9d7b7e12714aaf9559d4c2dd5..6b5f7be50b8ac2f6c8da6cae765c83c7422a416e 100644 (file)
@@ -162,6 +162,7 @@ struct w1_master
        int                     slave_ttl;
        int                     initialized;
        u32                     id;
+       int                     search_count;
 
        atomic_t                refcnt;
 
index 280f140ae698471a8b110ea51102290099a944ae..cf18f1324f03491112d7838c1a443e132bcf35ac 100644 (file)
@@ -69,6 +69,7 @@ static struct w1_master * w1_alloc_dev(u32 id, int slave_count, int slave_ttl,
        dev->initialized        = 0;
        dev->id                 = id;
        dev->slave_ttl          = slave_ttl;
+        dev->search_count      = -1; /* continual scan */
 
        atomic_set(&dev->refcnt, 2);