From: Martyn Welch <martyn.welch@ge.com>
To: Manohar Vanga <manohar.vanga@cern.ch>
Cc: gregkh@suse.de, cota@braap.org, devel@driverdev.osuosl.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH 3/8] staging: vme: make [alloc|free]_consistent bridge specific
Date: Mon, 01 Aug 2011 14:41:21 +0100 [thread overview]
Message-ID: <4E36AD01.1050004@ge.com> (raw)
In-Reply-To: <1312194053-32310-4-git-send-email-manohar.vanga@cern.ch>
On 01/08/11 11:20, Manohar Vanga wrote:
> Make PCI dependent functions ([alloc|free]_consistent() in
> 'vme.c') bridge specific. By removing the dependency of the
> VME bridge framework on PCI, this patch allows for addition of
> non-PCI based VME bridges.
>
I like the approach, I think I agree with Dan, I'd rather see the locking
inside the function for now.
Martyn
> Signed-off-by: Manohar Vanga <manohar.vanga@cern.ch>
> ---
> drivers/staging/vme/bridges/vme_ca91cx42.c | 24 ++++++++++++++++++++++
> drivers/staging/vme/bridges/vme_tsi148.c | 24 ++++++++++++++++++++++
> drivers/staging/vme/vme.c | 30 ++++++++++++++-------------
> drivers/staging/vme/vme_bridge.h | 10 ++++++--
> 4 files changed, 71 insertions(+), 17 deletions(-)
>
> diff --git a/drivers/staging/vme/bridges/vme_ca91cx42.c b/drivers/staging/vme/bridges/vme_ca91cx42.c
> index c378819..15a0b19 100644
> --- a/drivers/staging/vme/bridges/vme_ca91cx42.c
> +++ b/drivers/staging/vme/bridges/vme_ca91cx42.c
> @@ -1507,6 +1507,28 @@ static int ca91cx42_slot_get(struct vme_bridge *ca91cx42_bridge)
>
> }
>
> +void *ca91cx42_alloc_consistent(struct device *parent, size_t size,
> + dma_addr_t *dma)
> +{
> + struct pci_dev *pdev;
> +
> + /* Find pci_dev container of dev */
> + pdev = container_of(parent, struct pci_dev, dev);
> +
> + return pci_alloc_consistent(pdev, size, dma);
> +}
> +
> +void ca91cx42_free_consistent(struct device *parent, size_t size, void *vaddr,
> + dma_addr_t dma)
> +{
> + struct pci_dev *pdev;
> +
> + /* Find pci_dev container of dev */
> + pdev = container_of(parent, struct pci_dev, dev);
> +
> + pci_free_consistent(pdev, size, vaddr, dma);
> +}
> +
> static int __init ca91cx42_init(void)
> {
> return pci_register_driver(&ca91cx42_driver);
> @@ -1776,6 +1798,8 @@ static int ca91cx42_probe(struct pci_dev *pdev, const struct pci_device_id *id)
> ca91cx42_bridge->lm_attach = ca91cx42_lm_attach;
> ca91cx42_bridge->lm_detach = ca91cx42_lm_detach;
> ca91cx42_bridge->slot_get = ca91cx42_slot_get;
> + ca91cx42_bridge->alloc_consistent = ca91cx42_alloc_consistent;
> + ca91cx42_bridge->free_consistent = ca91cx42_free_consistent;
>
> data = ioread32(ca91cx42_device->base + MISC_CTL);
> dev_info(&pdev->dev, "Board is%s the VME system controller\n",
> diff --git a/drivers/staging/vme/bridges/vme_tsi148.c b/drivers/staging/vme/bridges/vme_tsi148.c
> index e3f021e..5c147d6 100644
> --- a/drivers/staging/vme/bridges/vme_tsi148.c
> +++ b/drivers/staging/vme/bridges/vme_tsi148.c
> @@ -2122,6 +2122,28 @@ static int tsi148_slot_get(struct vme_bridge *tsi148_bridge)
> return (int)slot;
> }
>
> +void *tsi148_alloc_consistent(struct device *parent, size_t size,
> + dma_addr_t *dma)
> +{
> + struct pci_dev *pdev;
> +
> + /* Find pci_dev container of dev */
> + pdev = container_of(parent, struct pci_dev, dev);
> +
> + return pci_alloc_consistent(pdev, size, dma);
> +}
> +
> +void tsi148_free_consistent(struct device *parent, size_t size, void *vaddr,
> + dma_addr_t dma)
> +{
> + struct pci_dev *pdev;
> +
> + /* Find pci_dev container of dev */
> + pdev = container_of(parent, struct pci_dev, dev);
> +
> + pci_free_consistent(pdev, size, vaddr, dma);
> +}
> +
> static int __init tsi148_init(void)
> {
> return pci_register_driver(&tsi148_driver);
> @@ -2451,6 +2473,8 @@ static int tsi148_probe(struct pci_dev *pdev, const struct pci_device_id *id)
> tsi148_bridge->lm_attach = tsi148_lm_attach;
> tsi148_bridge->lm_detach = tsi148_lm_detach;
> tsi148_bridge->slot_get = tsi148_slot_get;
> + tsi148_bridge->alloc_consistent = tsi148_alloc_consistent;
> + tsi148_bridge->free_consistent = tsi148_free_consistent;
>
> data = ioread32be(tsi148_device->base + TSI148_LCSR_VSTAT);
> dev_info(&pdev->dev, "Board is%s the VME system controller\n",
> diff --git a/drivers/staging/vme/vme.c b/drivers/staging/vme/vme.c
> index 330a4ff..bbede97 100644
> --- a/drivers/staging/vme/vme.c
> +++ b/drivers/staging/vme/vme.c
> @@ -83,15 +83,11 @@ static struct vme_bridge *find_bridge(struct vme_resource *resource)
> /*
> * Allocate a contiguous block of memory for use by the driver. This is used to
> * create the buffers for the slave windows.
> - *
> - * XXX VME bridges could be available on buses other than PCI. At the momment
> - * this framework only supports PCI devices.
> */
> void *vme_alloc_consistent(struct vme_resource *resource, size_t size,
> dma_addr_t *dma)
> {
> struct vme_bridge *bridge;
> - struct pci_dev *pdev;
>
> if (resource == NULL) {
> printk(KERN_ERR "No resource\n");
> @@ -104,28 +100,27 @@ void *vme_alloc_consistent(struct vme_resource *resource, size_t size,
> return NULL;
> }
>
> - /* Find pci_dev container of dev */
> if (bridge->parent == NULL) {
> printk(KERN_ERR "Dev entry NULL\n");
> return NULL;
> }
> - pdev = container_of(bridge->parent, struct pci_dev, dev);
>
> - return pci_alloc_consistent(pdev, size, dma);
> + if (bridge->alloc_consistent == NULL) {
> + printk(KERN_ERR "alloc_consistent not supported by bridge\n");
> + return NULL;
> + }
> +
> + return bridge->alloc_consistent(bridge->parent, size, dma);
> }
> EXPORT_SYMBOL(vme_alloc_consistent);
>
> /*
> * Free previously allocated contiguous block of memory.
> - *
> - * XXX VME bridges could be available on buses other than PCI. At the momment
> - * this framework only supports PCI devices.
> */
> void vme_free_consistent(struct vme_resource *resource, size_t size,
> void *vaddr, dma_addr_t dma)
> {
> struct vme_bridge *bridge;
> - struct pci_dev *pdev;
>
> if (resource == NULL) {
> printk(KERN_ERR "No resource\n");
> @@ -138,10 +133,17 @@ void vme_free_consistent(struct vme_resource *resource, size_t size,
> return;
> }
>
> - /* Find pci_dev container of dev */
> - pdev = container_of(bridge->parent, struct pci_dev, dev);
> + if (bridge->parent == NULL) {
> + printk(KERN_ERR "Dev entry NULL\n");
> + return;
> + }
> +
> + if (bridge->free_consistent == NULL) {
> + printk(KERN_ERR "free_consistent not supported by bridge\n");
> + return;
> + }
>
> - pci_free_consistent(pdev, size, vaddr, dma);
> + bridge->free_consistent(bridge->parent, size, vaddr, dma);
> }
> EXPORT_SYMBOL(vme_free_consistent);
>
> diff --git a/drivers/staging/vme/vme_bridge.h b/drivers/staging/vme/vme_bridge.h
> index 4c6ec31..a9084f0 100644
> --- a/drivers/staging/vme/vme_bridge.h
> +++ b/drivers/staging/vme/vme_bridge.h
> @@ -98,8 +98,6 @@ struct vme_irq {
> /* This structure stores all the information about one bridge
> * The structure should be dynamically allocated by the driver and one instance
> * of the structure should be present for each VME chip present in the system.
> - *
> - * Currently we assume that all chips are PCI-based
> */
> struct vme_bridge {
> char name[VMENAMSIZ];
> @@ -112,7 +110,7 @@ struct vme_bridge {
> struct list_head vme_errors; /* List for errors generated on VME */
>
> /* Bridge Info - XXX Move to private structure? */
> - struct device *parent; /* Generic device struct (pdev->dev for PCI) */
> + struct device *parent; /* Parent device (eg. pdev->dev for PCI) */
> void *driver_priv; /* Private pointer for the bridge driver */
>
> struct device dev[VME_SLOTS_MAX]; /* Device registered with
> @@ -165,6 +163,12 @@ struct vme_bridge {
>
> /* CR/CSR space functions */
> int (*slot_get) (struct vme_bridge *);
> +
> + /* Bridge parent interface */
> + void *(*alloc_consistent)(struct device *dev, size_t size,
> + dma_addr_t *dma);
> + void (*free_consistent)(struct device *dev, size_t size,
> + void *vaddr, dma_addr_t dma);
> };
>
> void vme_irq_handler(struct vme_bridge *, int, int);
--
Martyn Welch (Principal Software Engineer) | Registered in England and
GE Intelligent Platforms | Wales (3828642) at 100
T +44(0)127322748 | Barbirolli Square, Manchester,
E martyn.welch@ge.com | M2 3AB VAT:GB 927559189
next prev parent reply other threads:[~2011-08-01 13:41 UTC|newest]
Thread overview: 64+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-08-01 10:20 [PATCH 0/8] VME Driver Fixes Manohar Vanga
2011-08-01 10:20 ` [PATCH 1/8] staging: vme_user: change kmalloc+memset to kzalloc Manohar Vanga
2011-08-01 10:52 ` Martyn Welch
2011-08-10 7:44 ` Martyn Welch
2011-08-01 10:20 ` [PATCH 2/8] staging: vme: allow explicit assignment of bus numbers Manohar Vanga
2011-08-01 11:10 ` Dan Carpenter
2011-08-01 12:12 ` Manohar Vanga
2011-08-01 13:06 ` Martyn Welch
2011-08-01 14:31 ` Manohar Vanga
2011-08-01 15:50 ` Martyn Welch
2011-08-02 11:54 ` Manohar Vanga
2011-08-02 14:57 ` Martyn Welch
2011-08-03 8:54 ` Martyn Welch
2011-08-04 9:16 ` Manohar Vanga
2011-08-01 10:20 ` [PATCH 3/8] staging: vme: make [alloc|free]_consistent bridge specific Manohar Vanga
2011-08-01 11:10 ` Dan Carpenter
2011-08-01 12:24 ` Manohar Vanga
2011-08-01 13:41 ` Martyn Welch [this message]
2011-08-01 13:40 ` Manohar Vanga
2011-08-01 14:00 ` Manohar Vanga
2011-08-01 14:05 ` Martyn Welch
2011-08-01 10:20 ` [PATCH 4/8] staging: vme: keep track of registered buses Manohar Vanga
2011-08-01 10:20 ` [PATCH 5/8] staging: vme: add functions for bridge module refcounting Manohar Vanga
2011-08-03 14:04 ` Martyn Welch
2011-08-03 14:06 ` Manohar Vanga
2011-08-03 15:23 ` Emilio G. Cota
2011-08-04 7:23 ` Martyn Welch
2011-08-04 16:34 ` Emilio G. Cota
2011-08-05 7:45 ` Martyn Welch
2011-08-05 9:04 ` Manohar Vanga
2011-08-05 9:24 ` Martyn Welch
2011-08-05 17:47 ` Emilio G. Cota
2011-08-08 8:01 ` Martyn Welch
2011-08-08 9:14 ` Emilio G. Cota
2011-08-08 9:42 ` Martyn Welch
[not found] ` <4E3FABDA.8080204@ge.com>
[not found] ` <20110808101140.GA21300@flamenco.cs.columbia.edu>
2011-08-08 11:06 ` Martyn Welch
2011-08-08 17:22 ` Emilio G. Cota
2011-08-08 18:04 ` Greg KH
2011-08-09 9:00 ` Martyn Welch
2011-08-09 19:19 ` Emilio G. Cota
2011-08-10 7:39 ` Martyn Welch
2011-08-10 9:15 ` Emilio G. Cota
2011-08-10 9:50 ` Martyn Welch
2011-08-10 18:35 ` Emilio G. Cota
2011-08-09 13:24 ` Manohar Vanga
2011-08-09 14:26 ` Martyn Welch
2011-08-09 14:35 ` Manohar Vanga
2011-08-09 15:05 ` Martyn Welch
2011-08-09 18:49 ` Emilio G. Cota
2011-08-10 6:52 ` Manohar Vanga
2011-08-01 10:20 ` [PATCH 6/8] staging: vme: rename *_slot_get to *_get_slot Manohar Vanga
2011-08-01 12:29 ` Martyn Welch
2011-08-01 12:31 ` Manohar Vanga
2011-08-09 15:18 ` Martyn Welch
2011-08-09 15:25 ` Greg KH
2011-08-09 15:32 ` Manohar Vanga
2011-08-01 10:20 ` [PATCH 7/8] staging: vme: add struct vme_dev for VME devices Manohar Vanga
2011-08-09 15:19 ` Martyn Welch
2011-08-01 10:20 ` [PATCH 8/8] staging: vme: make match() driver specific to improve non-VME64x support Manohar Vanga
2011-08-03 9:16 ` Martyn Welch
2011-08-03 12:18 ` Manohar Vanga
2011-08-01 14:29 ` [PATCH 0/8] VME Driver Fixes Martyn Welch
2011-08-01 14:32 ` Manohar Vanga
2011-08-23 22:07 ` Greg KH
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=4E36AD01.1050004@ge.com \
--to=martyn.welch@ge.com \
--cc=cota@braap.org \
--cc=devel@driverdev.osuosl.org \
--cc=gregkh@suse.de \
--cc=linux-kernel@vger.kernel.org \
--cc=manohar.vanga@cern.ch \
/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