]> err.no Git - linux-2.6/commitdiff
kref: add kref_set()
authorEvgeniy Polyakov <johnpol@2ka.mipt.ru>
Mon, 10 Dec 2007 20:03:43 +0000 (23:03 +0300)
committerGreg Kroah-Hartman <gregkh@suse.de>
Fri, 25 Jan 2008 04:40:05 +0000 (20:40 -0800)
This adds kref_set() to the kref api for future use by people who really
know what they are doing with krefs...

From: Evgeniy Polyakov <johnpol@2ka.mipt.ru>
Cc: Kay Sievers <kay.sievers@vrfy.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
include/linux/kref.h
lib/kref.c

index 6fee3539893f6f93d5634ec099f5741e4d1ccb95..5d185635786e129a35c28f475fdbb879cf78558b 100644 (file)
@@ -24,6 +24,7 @@ struct kref {
        atomic_t refcount;
 };
 
+void kref_set(struct kref *kref, int num);
 void kref_init(struct kref *kref);
 void kref_get(struct kref *kref);
 int kref_put(struct kref *kref, void (*release) (struct kref *kref));
index a6dc3ec328e05fc8da4d69d185d13a5758ac0464..9ecd6e86561034f2a097bcc027765704e124f7df 100644 (file)
 #include <linux/kref.h>
 #include <linux/module.h>
 
+/**
+ * kref_set - initialize object and set refcount to requested number.
+ * @kref: object in question.
+ * @num: initial reference counter
+ */
+void kref_set(struct kref *kref, int num)
+{
+       atomic_set(&kref->refcount, num);
+       smp_mb();
+}
+
 /**
  * kref_init - initialize object.
  * @kref: object in question.
  */
 void kref_init(struct kref *kref)
 {
-       atomic_set(&kref->refcount,1);
-       smp_mb();
+       kref_set(kref, 1);
 }
 
 /**
@@ -61,6 +71,7 @@ int kref_put(struct kref *kref, void (*release)(struct kref *kref))
        return 0;
 }
 
+EXPORT_SYMBOL(kref_set);
 EXPORT_SYMBOL(kref_init);
 EXPORT_SYMBOL(kref_get);
 EXPORT_SYMBOL(kref_put);