kernel: update linux 3.3 to 3.3.1
[openwrt/staging/mkresin.git] / target / linux / generic / patches-3.3 / 910-kobject_uevent.patch
index f15749fa1780d5680c596a302bb9a5b0f942cc66..aa9a40f0998100b97c1fd4303c54f4d992d08194 100644 (file)
@@ -1,6 +1,6 @@
 --- a/lib/kobject_uevent.c
 +++ b/lib/kobject_uevent.c
 --- a/lib/kobject_uevent.c
 +++ b/lib/kobject_uevent.c
-@@ -49,6 +49,18 @@ static const char *kobject_actions[] = {
+@@ -50,6 +50,18 @@ static const char *kobject_actions[] = {
        [KOBJ_OFFLINE] =        "offline",
  };
  
        [KOBJ_OFFLINE] =        "offline",
  };
  
@@ -8,9 +8,9 @@
 +{
 +      u64 seq;
 +
 +{
 +      u64 seq;
 +
-+      spin_lock(&sequence_lock);
++      mutex_lock(&uevent_sock_mutex);
 +      seq = ++uevent_seqnum;
 +      seq = ++uevent_seqnum;
-+      spin_unlock(&sequence_lock);
++      mutex_unlock(&uevent_sock_mutex);
 +
 +      return seq;
 +}
 +
 +      return seq;
 +}
  /**
   * kobject_action_type - translate action string to numeric type
   *
  /**
   * kobject_action_type - translate action string to numeric type
   *
-@@ -244,9 +256,7 @@ int kobject_uevent_env(struct kobject *k
-               kobj->state_remove_uevent_sent = 1;
-       /* we will send an event, so request a new sequence number */
--      spin_lock(&sequence_lock);
--      seq = ++uevent_seqnum;
--      spin_unlock(&sequence_lock);
-+      seq = uevent_next_seqnum();
-       retval = add_uevent_var(env, "SEQNUM=%llu", (unsigned long long)seq);
-       if (retval)
-               goto exit;