RE: [RESEND x2][PATCH v2] block: partition: Add partition specific uevent callbacks for partition info

2016-02-05 Thread Caizhiyong
> > Interestingly, this feature appears to already be documented in
> > Documentation/block/cmdline-partition.txt.  I wonder how that happened.
> > Maybe we used to do this but it got taken away?

This documentation talk about the partition name usages, 
my patch support get partition name from android userspace.
the mainline kernel appears does not support the 'PARTNAME' uevent, but this 
feature is very convenient.

> 
> Heh. Looks like the documentation was added not too long ago (by Cai -
> cc'ed). I suspect they had been working w/ the Android tree and
> assumed the functionality was already upstream?
> 
> > It seems bad that we don't document uevents in any organized fashion.
> > But the audience is very small and knows how to find kernel source code
> > so I guess it doesn't matter.
> >
> > Anyway, please do check that the conveniently self-adding documentation
> > is accurate and complete.
> 
> It does match the behavior this patch provides from Android. It is
> somewhat tangential to the functionality described in the
> documentation, so I'm not sure of its measure of completeness (for
> example, it doesn't talk about PARTN parameter, but again, the
> documentation is covering how to specify partition info via the boot
> cmdline, and isn't really covering the uevents - the uevent was just a
> mentioned side-effect for the partition name portion of the cmdline
> option).
> 
> thanks
> -john


Re: [RESEND x2][PATCH v2] block: partition: Add partition specific uevent callbacks for partition info

2016-02-05 Thread John Stultz
On Fri, Feb 5, 2016 at 10:18 AM, Andrew Morton
 wrote:
> On Fri,  5 Feb 2016 10:01:43 -0800 John Stultz  wrote:
>
>> From: San Mehat 
>>
>> This patch has been carried in the Android tree for quite some
>> time and is one of the few patches required to get a mainline
>> kernel up and running with an exsiting Android userspace. So I
>> wanted to submit it for review and consideration if it should
>> be merged.
>>
>> For partitions, add new uevent parameters 'PARTN' which
>> specifies the partitions index in the table, and 'PARTNAME',
>> which specifies PARTNAME specifices the partition name of a
>> partition device.
>>
>> Android's userspace uses this for creating device node links from the
>> partition name and number: ie:
>>   /dev/block/platform/soc/by-name/system
>> or
>>   /dev/block/platform/soc/by-num/p1
>>
>> One can see its usage here:
>> https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#355
>> and
>> https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#494
>>
>> ...
>>
>> --- a/block/partition-generic.c
>> +++ b/block/partition-generic.c
>> @@ -216,10 +216,21 @@ static void part_release(struct device *dev)
>>   kfree(p);
>>  }
>>
>> +static int part_uevent(struct device *dev, struct kobj_uevent_env *env)
>> +{
>> + struct hd_struct *part = dev_to_part(dev);
>> +
>> + add_uevent_var(env, "PARTN=%u", part->partno);
>> + if (part->info && part->info->volname[0])
>> + add_uevent_var(env, "PARTNAME=%s", part->info->volname);
>> + return 0;
>> +}
>> +
>>  struct device_type part_type = {
>>   .name   = "partition",
>>   .groups = part_attr_groups,
>>   .release= part_release,
>> + .uevent = part_uevent,
>>  };
>>
>>  static void delete_partition_rcu_cb(struct rcu_head *head)
>
> Interestingly, this feature appears to already be documented in
> Documentation/block/cmdline-partition.txt.  I wonder how that happened.
> Maybe we used to do this but it got taken away?

Heh. Looks like the documentation was added not too long ago (by Cai -
cc'ed). I suspect they had been working w/ the Android tree and
assumed the functionality was already upstream?

> It seems bad that we don't document uevents in any organized fashion.
> But the audience is very small and knows how to find kernel source code
> so I guess it doesn't matter.
>
> Anyway, please do check that the conveniently self-adding documentation
> is accurate and complete.

It does match the behavior this patch provides from Android. It is
somewhat tangential to the functionality described in the
documentation, so I'm not sure of its measure of completeness (for
example, it doesn't talk about PARTN parameter, but again, the
documentation is covering how to specify partition info via the boot
cmdline, and isn't really covering the uevents - the uevent was just a
mentioned side-effect for the partition name portion of the cmdline
option).

thanks
-john


Re: [RESEND x2][PATCH v2] block: partition: Add partition specific uevent callbacks for partition info

2016-02-05 Thread Andrew Morton
On Fri,  5 Feb 2016 10:01:43 -0800 John Stultz  wrote:

> From: San Mehat 
> 
> This patch has been carried in the Android tree for quite some
> time and is one of the few patches required to get a mainline
> kernel up and running with an exsiting Android userspace. So I
> wanted to submit it for review and consideration if it should
> be merged.
> 
> For partitions, add new uevent parameters 'PARTN' which
> specifies the partitions index in the table, and 'PARTNAME',
> which specifies PARTNAME specifices the partition name of a
> partition device.
> 
> Android's userspace uses this for creating device node links from the
> partition name and number: ie:
>   /dev/block/platform/soc/by-name/system
> or
>   /dev/block/platform/soc/by-num/p1
> 
> One can see its usage here:
> https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#355
> and
> https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#494
> 
> ...
>
> --- a/block/partition-generic.c
> +++ b/block/partition-generic.c
> @@ -216,10 +216,21 @@ static void part_release(struct device *dev)
>   kfree(p);
>  }
>  
> +static int part_uevent(struct device *dev, struct kobj_uevent_env *env)
> +{
> + struct hd_struct *part = dev_to_part(dev);
> +
> + add_uevent_var(env, "PARTN=%u", part->partno);
> + if (part->info && part->info->volname[0])
> + add_uevent_var(env, "PARTNAME=%s", part->info->volname);
> + return 0;
> +}
> +
>  struct device_type part_type = {
>   .name   = "partition",
>   .groups = part_attr_groups,
>   .release= part_release,
> + .uevent = part_uevent,
>  };
>  
>  static void delete_partition_rcu_cb(struct rcu_head *head)

Interestingly, this feature appears to already be documented in
Documentation/block/cmdline-partition.txt.  I wonder how that happened.
Maybe we used to do this but it got taken away?

It seems bad that we don't document uevents in any organized fashion. 
But the audience is very small and knows how to find kernel source code
so I guess it doesn't matter.

Anyway, please do check that the conveniently self-adding documentation
is accurate and complete.


[RESEND x2][PATCH v2] block: partition: Add partition specific uevent callbacks for partition info

2016-02-05 Thread John Stultz
From: San Mehat 

This patch has been carried in the Android tree for quite some
time and is one of the few patches required to get a mainline
kernel up and running with an exsiting Android userspace. So I
wanted to submit it for review and consideration if it should
be merged.

For partitions, add new uevent parameters 'PARTN' which
specifies the partitions index in the table, and 'PARTNAME',
which specifies PARTNAME specifices the partition name of a
partition device.

Android's userspace uses this for creating device node links from the
partition name and number: ie:
/dev/block/platform/soc/by-name/system
or
/dev/block/platform/soc/by-num/p1

One can see its usage here:
https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#355
and
https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#494

Cc: Jens Axboe 
Cc: Rom Lemarchand 
Cc: Android Kernel Team 
Cc: Jeff Moyer 
Cc: har...@redhat.com
Cc: Kees Cook 
Cc: Andrew Morton 
Cc: Kay Sievers 
Signed-off-by: Dima Zavin 
[Dropped NPARTS and reworded commit message for context]
Signed-off-by: John Stultz 
---
v2: Dropped NPARTS thanks to Jeff noticing it wasn't used

 block/partition-generic.c | 11 +++
 1 file changed, 11 insertions(+)

diff --git a/block/partition-generic.c b/block/partition-generic.c
index 746935a..ae95e96 100644
--- a/block/partition-generic.c
+++ b/block/partition-generic.c
@@ -216,10 +216,21 @@ static void part_release(struct device *dev)
kfree(p);
 }
 
+static int part_uevent(struct device *dev, struct kobj_uevent_env *env)
+{
+   struct hd_struct *part = dev_to_part(dev);
+
+   add_uevent_var(env, "PARTN=%u", part->partno);
+   if (part->info && part->info->volname[0])
+   add_uevent_var(env, "PARTNAME=%s", part->info->volname);
+   return 0;
+}
+
 struct device_type part_type = {
.name   = "partition",
.groups = part_attr_groups,
.release= part_release,
+   .uevent = part_uevent,
 };
 
 static void delete_partition_rcu_cb(struct rcu_head *head)
-- 
1.9.1



Re: [RESEND x2][PATCH v2] block: partition: Add partition specific uevent callbacks for partition info

2016-02-05 Thread Andrew Morton
On Fri,  5 Feb 2016 10:01:43 -0800 John Stultz  wrote:

> From: San Mehat 
> 
> This patch has been carried in the Android tree for quite some
> time and is one of the few patches required to get a mainline
> kernel up and running with an exsiting Android userspace. So I
> wanted to submit it for review and consideration if it should
> be merged.
> 
> For partitions, add new uevent parameters 'PARTN' which
> specifies the partitions index in the table, and 'PARTNAME',
> which specifies PARTNAME specifices the partition name of a
> partition device.
> 
> Android's userspace uses this for creating device node links from the
> partition name and number: ie:
>   /dev/block/platform/soc/by-name/system
> or
>   /dev/block/platform/soc/by-num/p1
> 
> One can see its usage here:
> https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#355
> and
> https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#494
> 
> ...
>
> --- a/block/partition-generic.c
> +++ b/block/partition-generic.c
> @@ -216,10 +216,21 @@ static void part_release(struct device *dev)
>   kfree(p);
>  }
>  
> +static int part_uevent(struct device *dev, struct kobj_uevent_env *env)
> +{
> + struct hd_struct *part = dev_to_part(dev);
> +
> + add_uevent_var(env, "PARTN=%u", part->partno);
> + if (part->info && part->info->volname[0])
> + add_uevent_var(env, "PARTNAME=%s", part->info->volname);
> + return 0;
> +}
> +
>  struct device_type part_type = {
>   .name   = "partition",
>   .groups = part_attr_groups,
>   .release= part_release,
> + .uevent = part_uevent,
>  };
>  
>  static void delete_partition_rcu_cb(struct rcu_head *head)

Interestingly, this feature appears to already be documented in
Documentation/block/cmdline-partition.txt.  I wonder how that happened.
Maybe we used to do this but it got taken away?

It seems bad that we don't document uevents in any organized fashion. 
But the audience is very small and knows how to find kernel source code
so I guess it doesn't matter.

Anyway, please do check that the conveniently self-adding documentation
is accurate and complete.


Re: [RESEND x2][PATCH v2] block: partition: Add partition specific uevent callbacks for partition info

2016-02-05 Thread John Stultz
On Fri, Feb 5, 2016 at 10:18 AM, Andrew Morton
 wrote:
> On Fri,  5 Feb 2016 10:01:43 -0800 John Stultz  wrote:
>
>> From: San Mehat 
>>
>> This patch has been carried in the Android tree for quite some
>> time and is one of the few patches required to get a mainline
>> kernel up and running with an exsiting Android userspace. So I
>> wanted to submit it for review and consideration if it should
>> be merged.
>>
>> For partitions, add new uevent parameters 'PARTN' which
>> specifies the partitions index in the table, and 'PARTNAME',
>> which specifies PARTNAME specifices the partition name of a
>> partition device.
>>
>> Android's userspace uses this for creating device node links from the
>> partition name and number: ie:
>>   /dev/block/platform/soc/by-name/system
>> or
>>   /dev/block/platform/soc/by-num/p1
>>
>> One can see its usage here:
>> https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#355
>> and
>> https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#494
>>
>> ...
>>
>> --- a/block/partition-generic.c
>> +++ b/block/partition-generic.c
>> @@ -216,10 +216,21 @@ static void part_release(struct device *dev)
>>   kfree(p);
>>  }
>>
>> +static int part_uevent(struct device *dev, struct kobj_uevent_env *env)
>> +{
>> + struct hd_struct *part = dev_to_part(dev);
>> +
>> + add_uevent_var(env, "PARTN=%u", part->partno);
>> + if (part->info && part->info->volname[0])
>> + add_uevent_var(env, "PARTNAME=%s", part->info->volname);
>> + return 0;
>> +}
>> +
>>  struct device_type part_type = {
>>   .name   = "partition",
>>   .groups = part_attr_groups,
>>   .release= part_release,
>> + .uevent = part_uevent,
>>  };
>>
>>  static void delete_partition_rcu_cb(struct rcu_head *head)
>
> Interestingly, this feature appears to already be documented in
> Documentation/block/cmdline-partition.txt.  I wonder how that happened.
> Maybe we used to do this but it got taken away?

Heh. Looks like the documentation was added not too long ago (by Cai -
cc'ed). I suspect they had been working w/ the Android tree and
assumed the functionality was already upstream?

> It seems bad that we don't document uevents in any organized fashion.
> But the audience is very small and knows how to find kernel source code
> so I guess it doesn't matter.
>
> Anyway, please do check that the conveniently self-adding documentation
> is accurate and complete.

It does match the behavior this patch provides from Android. It is
somewhat tangential to the functionality described in the
documentation, so I'm not sure of its measure of completeness (for
example, it doesn't talk about PARTN parameter, but again, the
documentation is covering how to specify partition info via the boot
cmdline, and isn't really covering the uevents - the uevent was just a
mentioned side-effect for the partition name portion of the cmdline
option).

thanks
-john


[RESEND x2][PATCH v2] block: partition: Add partition specific uevent callbacks for partition info

2016-02-05 Thread John Stultz
From: San Mehat 

This patch has been carried in the Android tree for quite some
time and is one of the few patches required to get a mainline
kernel up and running with an exsiting Android userspace. So I
wanted to submit it for review and consideration if it should
be merged.

For partitions, add new uevent parameters 'PARTN' which
specifies the partitions index in the table, and 'PARTNAME',
which specifies PARTNAME specifices the partition name of a
partition device.

Android's userspace uses this for creating device node links from the
partition name and number: ie:
/dev/block/platform/soc/by-name/system
or
/dev/block/platform/soc/by-num/p1

One can see its usage here:
https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#355
and
https://android.googlesource.com/platform/system/core/+/master/init/devices.cpp#494

Cc: Jens Axboe 
Cc: Rom Lemarchand 
Cc: Android Kernel Team 
Cc: Jeff Moyer 
Cc: har...@redhat.com
Cc: Kees Cook 
Cc: Andrew Morton 
Cc: Kay Sievers 
Signed-off-by: Dima Zavin 
[Dropped NPARTS and reworded commit message for context]
Signed-off-by: John Stultz 
---
v2: Dropped NPARTS thanks to Jeff noticing it wasn't used

 block/partition-generic.c | 11 +++
 1 file changed, 11 insertions(+)

diff --git a/block/partition-generic.c b/block/partition-generic.c
index 746935a..ae95e96 100644
--- a/block/partition-generic.c
+++ b/block/partition-generic.c
@@ -216,10 +216,21 @@ static void part_release(struct device *dev)
kfree(p);
 }
 
+static int part_uevent(struct device *dev, struct kobj_uevent_env *env)
+{
+   struct hd_struct *part = dev_to_part(dev);
+
+   add_uevent_var(env, "PARTN=%u", part->partno);
+   if (part->info && part->info->volname[0])
+   add_uevent_var(env, "PARTNAME=%s", part->info->volname);
+   return 0;
+}
+
 struct device_type part_type = {
.name   = "partition",
.groups = part_attr_groups,
.release= part_release,
+   .uevent = part_uevent,
 };
 
 static void delete_partition_rcu_cb(struct rcu_head *head)
-- 
1.9.1



RE: [RESEND x2][PATCH v2] block: partition: Add partition specific uevent callbacks for partition info

2016-02-05 Thread Caizhiyong
> > Interestingly, this feature appears to already be documented in
> > Documentation/block/cmdline-partition.txt.  I wonder how that happened.
> > Maybe we used to do this but it got taken away?

This documentation talk about the partition name usages, 
my patch support get partition name from android userspace.
the mainline kernel appears does not support the 'PARTNAME' uevent, but this 
feature is very convenient.

> 
> Heh. Looks like the documentation was added not too long ago (by Cai -
> cc'ed). I suspect they had been working w/ the Android tree and
> assumed the functionality was already upstream?
> 
> > It seems bad that we don't document uevents in any organized fashion.
> > But the audience is very small and knows how to find kernel source code
> > so I guess it doesn't matter.
> >
> > Anyway, please do check that the conveniently self-adding documentation
> > is accurate and complete.
> 
> It does match the behavior this patch provides from Android. It is
> somewhat tangential to the functionality described in the
> documentation, so I'm not sure of its measure of completeness (for
> example, it doesn't talk about PARTN parameter, but again, the
> documentation is covering how to specify partition info via the boot
> cmdline, and isn't really covering the uevents - the uevent was just a
> mentioned side-effect for the partition name portion of the cmdline
> option).
> 
> thanks
> -john