All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jiang Liu <liuj97@gmail.com>
To: Toshi Kani <toshi.kani@hp.com>
Cc: Hanjun Guo <guohanjun@huawei.com>,
	Vasilis Liaskovitis <vasilis.liaskovitis@profitbricks.com>,
	linux-acpi@vger.kernel.org, isimatu.yasuaki@jp.fujitsu.com,
	wency@cn.fujitsu.com, rjw@sisk.pl, lenb@kernel.org,
	gregkh@linuxfoundation.org, linux-kernel@vger.kernel.org,
	linux-mm@kvack.org, Tang Chen <tangchen@cn.fujitsu.com>
Subject: Re: [RFC PATCH v3 0/3] acpi: Introduce prepare_remove device operation
Date: Fri, 07 Dec 2012 01:30:35 +0800	[thread overview]
Message-ID: <50C0D63B.10504@gmail.com> (raw)
In-Reply-To: <1354813754.21116.16.camel@misato.fc.hp.com>

On 12/07/2012 01:09 AM, Toshi Kani wrote:
> On Fri, 2012-12-07 at 00:52 +0800, Jiang Liu wrote:
>> On 12/07/2012 12:31 AM, Toshi Kani wrote:
>>> On Fri, 2012-12-07 at 00:25 +0800, Jiang Liu wrote:
>>>> On 12/07/2012 12:03 AM, Toshi Kani wrote:
>>>>> On Fri, 2012-12-07 at 00:00 +0800, Jiang Liu wrote:
>>>>>> On 11/29/2012 02:41 AM, Toshi Kani wrote:
>>>>>>> On Wed, 2012-11-28 at 19:05 +0800, Hanjun Guo wrote:
>>>  : 
>>>>>>> Yes, sharing idea is good. :)  I do not know if we need all 6 steps (I
>>>>>>> have not looked at all your changes yet..), but in my mind, a hot-plug
>>>>>>> operation should be composed with the following 3 phases.
>>>>>>>
>>>>>>> 1. Validate phase - Verify if the request is a supported operation.  All
>>>>>>> known restrictions are verified at this phase.  For instance, if a
>>>>>>> hot-remove request involves kernel memory, it is failed in this phase.
>>>>>>> Since this phase makes no change, no rollback is necessary to fail.  
>>>>>>>
>>>>>>> 2. Execute phase - Perform hot-add / hot-remove operation that can be
>>>>>>> rolled-back in case of error or cancel.
>>>>>>>
>>>>>>> 3. Commit phase - Perform the final hot-add / hot-remove operation that
>>>>>>> cannot be rolled-back.  No error / cancel is allowed in this phase.  For
>>>>>>> instance, eject operation is performed at this phase.  
>>>>>> Hi Toshi,
>>>>>> 	There are one more step needed. Linux provides sysfs interfaces to
>>>>>> online/offline CPU/memory sections, so we need to protect from concurrent
>>>>>> operations from those interfaces when doing physical hotplug. Think about
>>>>>> following sequence:
>>>>>> Thread 1
>>>>>> 1. validate conditions for hot-removal
>>>>>> 2. offline memory section A
>>>>>> 3.						online memory section A			
>>>>>> 4. offline memory section B
>>>>>> 5 hot-remove memory device hosting A and B.
>>>>>
>>>>> Hi Gerry,
>>>>>
>>>>> I agree.  And I am working on a proposal that tries to address this
>>>>> issue by integrating both sysfs and hotplug operations into a framework.
>>>> Hi Toshi,
>>>> 	But the sysfs for CPU and memory online/offline are platform independent
>>>> interfaces, and the ACPI based hotplug is platform dependent interfaces. I'm not
>>>> sure whether it's feasible to merge them. For example we still need offline interface
>>>> to stop using faulty CPUs on platform without physical hotplug capabilities.
>>>> 	We have solved this by adding a "busy" flag to the device, so the sysfs
>>>> will just return -EBUSY if the busy flag is set.
>>>
>>> I am making the framework code platform-independent so that it can
>>> handle both cases.  Well, I am still prototyping, so hopefully it will
>>> work. :)
>> Do you mean implementing a framework to manage hotplug of any type of devices?
>> That sounds like a huge plan:)
>>
>> Otherwise there may be a gap. CPU online/offline interface deals with logical
>> CPU, and hotplug driver deals with physical devices(processor). They may be different
>> by related objects.
> 
> Actually it is not a huge plan.  The framework I am thinking of is to
> enable a hotplug sequencer something analogous to do_initcalls() at the
> boot sequence.  I am not doing any huge re-work.  That said, I am
> currently testing my theory, so I won't promise anything, either. :)
Please do give us an update when you get any progress:)

> 
> Thanks,
> -Toshi
> 
> 


WARNING: multiple messages have this Message-ID (diff)
From: Jiang Liu <liuj97@gmail.com>
To: Toshi Kani <toshi.kani@hp.com>
Cc: Hanjun Guo <guohanjun@huawei.com>,
	Vasilis Liaskovitis <vasilis.liaskovitis@profitbricks.com>,
	linux-acpi@vger.kernel.org, isimatu.yasuaki@jp.fujitsu.com,
	wency@cn.fujitsu.com, rjw@sisk.pl, lenb@kernel.org,
	gregkh@linuxfoundation.org, linux-kernel@vger.kernel.org,
	linux-mm@kvack.org, Tang Chen <tangchen@cn.fujitsu.com>
Subject: Re: [RFC PATCH v3 0/3] acpi: Introduce prepare_remove device operation
Date: Fri, 07 Dec 2012 01:30:35 +0800	[thread overview]
Message-ID: <50C0D63B.10504@gmail.com> (raw)
In-Reply-To: <1354813754.21116.16.camel@misato.fc.hp.com>

On 12/07/2012 01:09 AM, Toshi Kani wrote:
> On Fri, 2012-12-07 at 00:52 +0800, Jiang Liu wrote:
>> On 12/07/2012 12:31 AM, Toshi Kani wrote:
>>> On Fri, 2012-12-07 at 00:25 +0800, Jiang Liu wrote:
>>>> On 12/07/2012 12:03 AM, Toshi Kani wrote:
>>>>> On Fri, 2012-12-07 at 00:00 +0800, Jiang Liu wrote:
>>>>>> On 11/29/2012 02:41 AM, Toshi Kani wrote:
>>>>>>> On Wed, 2012-11-28 at 19:05 +0800, Hanjun Guo wrote:
>>>  : 
>>>>>>> Yes, sharing idea is good. :)  I do not know if we need all 6 steps (I
>>>>>>> have not looked at all your changes yet..), but in my mind, a hot-plug
>>>>>>> operation should be composed with the following 3 phases.
>>>>>>>
>>>>>>> 1. Validate phase - Verify if the request is a supported operation.  All
>>>>>>> known restrictions are verified at this phase.  For instance, if a
>>>>>>> hot-remove request involves kernel memory, it is failed in this phase.
>>>>>>> Since this phase makes no change, no rollback is necessary to fail.  
>>>>>>>
>>>>>>> 2. Execute phase - Perform hot-add / hot-remove operation that can be
>>>>>>> rolled-back in case of error or cancel.
>>>>>>>
>>>>>>> 3. Commit phase - Perform the final hot-add / hot-remove operation that
>>>>>>> cannot be rolled-back.  No error / cancel is allowed in this phase.  For
>>>>>>> instance, eject operation is performed at this phase.  
>>>>>> Hi Toshi,
>>>>>> 	There are one more step needed. Linux provides sysfs interfaces to
>>>>>> online/offline CPU/memory sections, so we need to protect from concurrent
>>>>>> operations from those interfaces when doing physical hotplug. Think about
>>>>>> following sequence:
>>>>>> Thread 1
>>>>>> 1. validate conditions for hot-removal
>>>>>> 2. offline memory section A
>>>>>> 3.						online memory section A			
>>>>>> 4. offline memory section B
>>>>>> 5 hot-remove memory device hosting A and B.
>>>>>
>>>>> Hi Gerry,
>>>>>
>>>>> I agree.  And I am working on a proposal that tries to address this
>>>>> issue by integrating both sysfs and hotplug operations into a framework.
>>>> Hi Toshi,
>>>> 	But the sysfs for CPU and memory online/offline are platform independent
>>>> interfaces, and the ACPI based hotplug is platform dependent interfaces. I'm not
>>>> sure whether it's feasible to merge them. For example we still need offline interface
>>>> to stop using faulty CPUs on platform without physical hotplug capabilities.
>>>> 	We have solved this by adding a "busy" flag to the device, so the sysfs
>>>> will just return -EBUSY if the busy flag is set.
>>>
>>> I am making the framework code platform-independent so that it can
>>> handle both cases.  Well, I am still prototyping, so hopefully it will
>>> work. :)
>> Do you mean implementing a framework to manage hotplug of any type of devices?
>> That sounds like a huge plan:)
>>
>> Otherwise there may be a gap. CPU online/offline interface deals with logical
>> CPU, and hotplug driver deals with physical devices(processor). They may be different
>> by related objects.
> 
> Actually it is not a huge plan.  The framework I am thinking of is to
> enable a hotplug sequencer something analogous to do_initcalls() at the
> boot sequence.  I am not doing any huge re-work.  That said, I am
> currently testing my theory, so I won't promise anything, either. :)
Please do give us an update when you get any progress:)

> 
> Thanks,
> -Toshi
> 
> 

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>

  reply	other threads:[~2012-12-06 17:30 UTC|newest]

Thread overview: 191+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-11-23 17:50 [RFC PATCH v3 0/3] acpi: Introduce prepare_remove device operation Vasilis Liaskovitis
2012-11-23 17:50 ` Vasilis Liaskovitis
2012-11-23 17:50 ` [RFC PATCH v3 1/3] acpi: Introduce prepare_remove operation in acpi_device_ops Vasilis Liaskovitis
2012-11-23 17:50   ` Vasilis Liaskovitis
2012-11-27  0:10   ` Toshi Kani
2012-11-27  0:10     ` Toshi Kani
2012-11-27 18:36     ` Vasilis Liaskovitis
2012-11-27 18:36       ` Vasilis Liaskovitis
2012-11-27 23:18     ` Rafael J. Wysocki
2012-11-27 23:18       ` Rafael J. Wysocki
2012-11-23 17:50 ` [RFC PATCH v3 2/3] acpi_memhotplug: Add prepare_remove operation Vasilis Liaskovitis
2012-11-23 17:50   ` Vasilis Liaskovitis
2012-11-24 16:23   ` Wen Congyang
2012-11-24 16:23     ` Wen Congyang
2012-11-23 17:50 ` [RFC PATCH v3 3/3] acpi_memhotplug: Allow eject to proceed on rebind scenario Vasilis Liaskovitis
2012-11-23 17:50   ` Vasilis Liaskovitis
2012-11-24 16:20   ` Wen Congyang
2012-11-24 16:20     ` Wen Congyang
2012-11-26  8:36     ` Vasilis Liaskovitis
2012-11-26  8:36       ` Vasilis Liaskovitis
2012-11-26  9:11       ` Wen Congyang
2012-11-26  9:11         ` Wen Congyang
2012-11-27  0:19         ` Toshi Kani
2012-11-27  0:19           ` Toshi Kani
2012-11-27 18:32           ` Vasilis Liaskovitis
2012-11-27 18:32             ` Vasilis Liaskovitis
2012-11-27 22:03             ` Toshi Kani
2012-11-27 22:03               ` Toshi Kani
2012-11-27 23:41               ` Rafael J. Wysocki
2012-11-27 23:41                 ` Rafael J. Wysocki
2012-11-28 16:01                 ` Toshi Kani
2012-11-28 16:01                   ` Toshi Kani
2012-11-28 18:40                   ` Rafael J. Wysocki
2012-11-28 18:40                     ` Rafael J. Wysocki
2012-11-28 21:02                     ` Toshi Kani
2012-11-28 21:02                       ` Toshi Kani
2012-11-28 21:40                       ` Rafael J. Wysocki
2012-11-28 21:40                         ` Rafael J. Wysocki
2012-11-28 21:40                         ` Toshi Kani
2012-11-28 21:40                           ` Toshi Kani
2012-11-28 22:01                           ` Rafael J. Wysocki
2012-11-28 22:01                             ` Rafael J. Wysocki
2012-11-28 22:04                             ` Toshi Kani
2012-11-28 22:04                               ` Toshi Kani
2012-11-28 22:21                               ` Rafael J. Wysocki
2012-11-28 22:21                                 ` Rafael J. Wysocki
2012-11-28 22:16                                 ` Toshi Kani
2012-11-28 22:16                                   ` Toshi Kani
2012-11-28 22:39                                   ` Rafael J. Wysocki
2012-11-28 22:39                                     ` Rafael J. Wysocki
2012-11-28 22:46                                     ` Greg KH
2012-11-28 22:46                                       ` Greg KH
2012-11-28 23:05                                       ` Rafael J. Wysocki
2012-11-28 23:05                                         ` Rafael J. Wysocki
2012-11-28 23:10                                         ` Greg KH
2012-11-28 23:10                                           ` Greg KH
2012-11-28 23:31                                           ` Rafael J. Wysocki
2012-11-28 23:31                                             ` Rafael J. Wysocki
2012-11-28 23:49                       ` Rafael J. Wysocki
2012-11-28 23:49                         ` Rafael J. Wysocki
2012-11-29  1:02                         ` Toshi Kani
2012-11-29  1:02                           ` Toshi Kani
2012-11-29  1:15                           ` Toshi Kani
2012-11-29  1:15                             ` Toshi Kani
2012-11-29 10:03                             ` Rafael J. Wysocki
2012-11-29 10:03                               ` Rafael J. Wysocki
2012-11-29 11:30                               ` Vasilis Liaskovitis
2012-11-29 11:30                                 ` Vasilis Liaskovitis
2012-11-29 16:57                                 ` Rafael J. Wysocki
2012-11-29 16:57                                   ` Rafael J. Wysocki
2012-11-29 17:56                                 ` Toshi Kani
2012-11-29 17:56                                   ` Toshi Kani
2012-11-29 20:25                                   ` Rafael J. Wysocki
2012-11-29 20:25                                     ` Rafael J. Wysocki
2012-11-29 20:38                                     ` Toshi Kani
2012-11-29 20:38                                       ` Toshi Kani
2012-11-29 21:23                                       ` Rafael J. Wysocki
2012-11-29 21:23                                         ` Rafael J. Wysocki
2012-11-29 21:46                                         ` Toshi Kani
2012-11-29 21:46                                           ` Toshi Kani
2012-11-29 22:11                                           ` Rafael J. Wysocki
2012-11-29 22:11                                             ` Rafael J. Wysocki
2012-11-29 23:17                                             ` Toshi Kani
2012-11-29 23:17                                               ` Toshi Kani
2012-11-30  0:13                                               ` Rafael J. Wysocki
2012-11-30  0:13                                                 ` Rafael J. Wysocki
2012-11-30  1:09                                                 ` Toshi Kani
2012-11-30  1:09                                                   ` Toshi Kani
2012-11-29 16:43                               ` Toshi Kani
2012-11-29 16:43                                 ` Toshi Kani
2012-11-29 11:04                             ` Vasilis Liaskovitis
2012-11-29 11:04                               ` Vasilis Liaskovitis
2012-11-29 17:44                               ` Toshi Kani
2012-11-29 17:44                                 ` Toshi Kani
2012-12-06  9:30                                 ` Vasilis Liaskovitis
2012-12-06  9:30                                   ` Vasilis Liaskovitis
2012-12-06 12:50                                   ` Rafael J. Wysocki
2012-12-06 12:50                                     ` Rafael J. Wysocki
2012-12-06 15:41                                     ` Toshi Kani
2012-12-06 15:41                                       ` Toshi Kani
2012-12-06 20:32                                       ` Rafael J. Wysocki
2012-12-06 20:32                                         ` Rafael J. Wysocki
2012-11-28 11:05 ` [RFC PATCH v3 0/3] acpi: Introduce prepare_remove device operation Hanjun Guo
2012-11-28 11:05   ` Hanjun Guo
2012-11-28 11:05   ` Hanjun Guo
2012-11-28 18:41   ` Toshi Kani
2012-11-28 18:41     ` Toshi Kani
2012-11-29  4:48     ` Hanjun Guo
2012-11-29  4:48       ` Hanjun Guo
2012-11-29  4:48       ` Hanjun Guo
2012-11-29 22:27       ` Toshi Kani
2012-11-29 22:27         ` Toshi Kani
2012-12-03  4:25         ` Hanjun Guo
2012-12-03  4:25           ` Hanjun Guo
2012-12-03  4:25           ` Hanjun Guo
2012-12-04  0:10           ` Toshi Kani
2012-12-04  0:10             ` Toshi Kani
2012-12-04  9:16             ` Hanjun Guo
2012-12-04  9:16               ` Hanjun Guo
2012-12-04  9:16               ` Hanjun Guo
2012-12-04 23:23               ` Toshi Kani
2012-12-04 23:23                 ` Toshi Kani
2012-12-05 12:10                 ` Hanjun Guo
2012-12-05 12:10                   ` Hanjun Guo
2012-12-05 12:10                   ` Hanjun Guo
2012-12-05 22:31                   ` Toshi Kani
2012-12-05 22:31                     ` Toshi Kani
2012-12-06 16:47                 ` Jiang Liu
2012-12-06 16:47                   ` Jiang Liu
2012-12-07  2:25                   ` Toshi Kani
2012-12-07  2:25                     ` Toshi Kani
2012-12-06 16:40             ` Jiang Liu
2012-12-06 16:40               ` Jiang Liu
2012-12-06 16:40               ` Jiang Liu
2012-12-06 20:30               ` Rafael J. Wysocki
2012-12-06 20:30                 ` Rafael J. Wysocki
2012-12-07  2:57               ` Toshi Kani
2012-12-07  2:57                 ` Toshi Kani
2012-12-07  5:57                 ` Jiang Liu
2012-12-07  5:57                   ` Jiang Liu
2012-12-07  5:57                   ` Jiang Liu
2012-12-08  1:08                   ` Toshi Kani
2012-12-08  1:08                     ` Toshi Kani
2012-12-11 14:34                     ` Jiang Liu
2012-12-11 14:34                       ` Jiang Liu
2012-12-13 14:42                       ` Toshi Kani
2012-12-13 14:42                         ` Toshi Kani
2012-12-13 15:15                         ` Jiang Liu
2012-12-13 15:15                           ` Jiang Liu
2012-12-15  1:19                           ` Toshi Kani
2012-12-15  1:19                             ` Toshi Kani
2012-11-29 10:15     ` Rafael J. Wysocki
2012-11-29 10:15       ` Rafael J. Wysocki
2012-11-29 11:36       ` Vasilis Liaskovitis
2012-11-29 11:36         ` Vasilis Liaskovitis
2012-12-06 16:59         ` Jiang Liu
2012-12-06 16:59           ` Jiang Liu
2012-11-29 17:03       ` Toshi Kani
2012-11-29 17:03         ` Toshi Kani
2012-11-29 20:30         ` Rafael J. Wysocki
2012-11-29 20:30           ` Rafael J. Wysocki
2012-11-29 20:39           ` Toshi Kani
2012-11-29 20:39             ` Toshi Kani
2012-11-29 20:56             ` Toshi Kani
2012-11-29 20:56               ` Toshi Kani
2012-11-29 21:25               ` Rafael J. Wysocki
2012-11-29 21:25                 ` Rafael J. Wysocki
2012-12-06 17:10                 ` Jiang Liu
2012-12-06 17:10                   ` Jiang Liu
2012-12-06 17:07           ` Jiang Liu
2012-12-06 17:07             ` Jiang Liu
2012-12-06 17:01         ` Jiang Liu
2012-12-06 17:01           ` Jiang Liu
2012-12-06 16:56       ` Jiang Liu
2012-12-06 16:56         ` Jiang Liu
2012-12-06 16:00     ` Jiang Liu
2012-12-06 16:00       ` Jiang Liu
2012-12-06 16:03       ` Toshi Kani
2012-12-06 16:03         ` Toshi Kani
2012-12-06 16:25         ` Jiang Liu
2012-12-06 16:25           ` Jiang Liu
2012-12-06 16:31           ` Toshi Kani
2012-12-06 16:31             ` Toshi Kani
2012-12-06 16:52             ` Jiang Liu
2012-12-06 16:52               ` Jiang Liu
2012-12-06 17:09               ` Toshi Kani
2012-12-06 17:09                 ` Toshi Kani
2012-12-06 17:30                 ` Jiang Liu [this message]
2012-12-06 17:30                   ` Jiang Liu
2012-12-06 17:28                   ` Toshi Kani
2012-12-06 17:28                     ` Toshi Kani

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=50C0D63B.10504@gmail.com \
    --to=liuj97@gmail.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=guohanjun@huawei.com \
    --cc=isimatu.yasuaki@jp.fujitsu.com \
    --cc=lenb@kernel.org \
    --cc=linux-acpi@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mm@kvack.org \
    --cc=rjw@sisk.pl \
    --cc=tangchen@cn.fujitsu.com \
    --cc=toshi.kani@hp.com \
    --cc=vasilis.liaskovitis@profitbricks.com \
    --cc=wency@cn.fujitsu.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.