public inbox for linux-acpi@vger.kernel.org
 help / color / mirror / Atom feed
From: Adam Belay <ambx1-IBH0VoN/3vPQT0dZR+AlfA@public.gmane.org>
To: Shaohua Li <shaohua.li-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
Cc: acpi-dev
	<acpi-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org>,
	Len <len.brown-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
Subject: Re: [RFC 0/2]convert ACPI driver model to Linux driver model
Date: Wed, 21 Sep 2005 00:31:47 -0400	[thread overview]
Message-ID: <20050921043147.GA14734@neo.rr.com> (raw)
In-Reply-To: <1126502542.5153.17.camel-ECwVeV2eNyQD0+JXs3kMbRL4W9x8LtSr@public.gmane.org>

Hi Shaohua,

I'm sorry for the late reply.

On Mon, Sep 12, 2005 at 01:22:22PM +0800, Shaohua Li wrote:
> Hi,
> I'm sending the patches out not for merging but for comments. The
> patches try to convert ACPI driver model to Linux driver model. There
> are still many things unsettled. If you have any
> comment/suggestion/requirement, please let me know.
> 
> 1. in my mind, acpi should export two sets of info in sysfs. One is
> current namespace subsystem, it should just export the firmware info.
> All acpi device/drivers related info don't export here. The other is
> ACPI bus. It's similar with other buses like PCI bus.

I'm not sure if we want to export the ACPI namespace in sysfs.  In
theory, we can attach most of that information on to the device tree
directly.  I agree that an ACPI bus would be useful.  I think it should
represent every device that can't be enumerated by another standard.

> 
> 2. I regard all devices which don't belong to physical buses in the DSDT
> as ACPI bus devices. Ideally, PCI devices, PNP devices & other devices
> should bind them to their physical buses. Since many devices listed in
> DSDT aren't in ACPI bus, this makes it impossible to convert current
> acpi driver model into Linux style. You might look at my patch, many
> routines required by Linux driver model are empty. Though we can't
> completely utilize the advantage of Linux driver model, the partial
> convert still benefits us many such as sysfs support and suspend/resume
> support.

This partial implementation has its advantages, but it's also important
to have a well defined plan of transition.  I think we should migrate the
ACPI code entirely to the linux driver model.  I've made some progress on
this issue.

> 
> 3. The acpi namespace hotplug interface looks strange. After we
> introduce ACPI bus (CPU is in the bus), we can send hotplug event
> through it. So I'd like to remove the namespace hotplug interface later.

Agreed.

> 
> There are something to prevent us from completely converting ACPI driver
> model to Linux style:
> 1. Current ACPI driver model can register drivers for all devices listed
> in DSDT. ACPI bus can't handle this.

I'm assuming you're referring to devices that don't need ACPI for
enumeration.  All other types shouldn't be a problem.

I've ran into this with some of my PCI bus code.  My current strategy is
to move the responsibility of attaching firmware data to the specific
device driver of the device in question rather than having the ACPI bus
handle it.  The idea is that only ACPI-aware drivers will utilize ACPI,
otherwise it will be ignored.  Essentially, ACPI aware devices will serve
as anchoring points for ACPI objects, including those that belong to the
ACPI Bus type.  Any comments?

> 2. Current ACPI hotplug (CPU/IO) relays on separate .add/.start
> callbacks, but Linux driver can only provide a .probe. We might split
> ACPI hotplug support to separate drivers.
> Since these, my patch just adds fake Linux driver model support, but it
> still is very useful.

This was also an issue that I came across.

Could you explain the role of .add/.start and why it's necessary?  It
may be reasonable to add this functionality to the Linux driver model
so that other drivers can utilize it.


I would appreciate any comments.

Thanks,
Adam


-------------------------------------------------------
SF.Net email is sponsored by:
Tame your development challenges with Apache's Geronimo App Server. 
Download it for free - -and be entered to win a 42" plasma tv or your very
own Sony(tm)PSP.  Click here to play: http://sourceforge.net/geronimo.php

  parent reply	other threads:[~2005-09-21  4:31 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-09-12  5:22 [RFC 0/2]convert ACPI driver model to Linux driver model Shaohua Li
     [not found] ` <1126502542.5153.17.camel-ECwVeV2eNyQD0+JXs3kMbRL4W9x8LtSr@public.gmane.org>
2005-09-12 17:57   ` Dominik Brodowski
     [not found]     ` <20050912175741.GA15324-X3ehHDuj6sIIGcDfoQAp7BvVK+yQ3ZXh@public.gmane.org>
2005-09-13  6:50       ` Shaohua Li
2005-09-21  4:56       ` Adam Belay
2005-09-21  4:31   ` Adam Belay [this message]
     [not found]     ` <20050921043147.GA14734-IBH0VoN/3vPQT0dZR+AlfA@public.gmane.org>
2005-09-21  5:37       ` Shaohua Li

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=20050921043147.GA14734@neo.rr.com \
    --to=ambx1-ibh0von/3vpqt0dzr+alfa@public.gmane.org \
    --cc=acpi-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org \
    --cc=len.brown-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org \
    --cc=shaohua.li-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org \
    /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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox