From mboxrd@z Thu Jan 1 00:00:00 1970 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: base64 Subject: [RFC] dmaengine: Add metadat_ops for dma_async_tx_descriptor From: Vinod Koul Message-Id: <20180710055230.GB3219@vkoul-mobl> Date: Tue, 10 Jul 2018 11:22:30 +0530 To: Peter Ujfalusi Cc: radheys@xilinx.com, vinod.koul@intel.com, lars@metafoo.de, michal.simek@xilinx.com, linux-kernel@vger.kernel.org, dmaengine@vger.kernel.org, dan.j.williams@intel.com, appanad@xilinx.com, linux-arm-kernel@lists.infradead.org List-ID: SGV5IFBldGVyLAoKU29ycnkgZm9yIGxhdGUgcmVzcG9uc2Ugb24gdGhpcy4uCgpPbiAwMS0wNi0x OCwgMTM6MjQsIFBldGVyIFVqZmFsdXNpIHdyb3RlOgo+IElmIHRoZSBETUEgc3VwcG9ydHMgcGVy IGRlc2NyaXB0b3IgbWV0YWRhdGEgaXQgY2FuIGltcGxlbWVudCB0aGUgYXR0YWNoLAo+IGdldF9w dHIvc2V0X2xlbiBjYWxsYmFja3MuCj4gCj4gQ2xpZW50IGRyaXZlcnMgbXVzdCBvbmx5IHVzZSBl aXRoZXIgYXR0YWNoIG9yIGdldF9wdHIvc2V0X2xlbiB0byBhdm9pZAo+IG1pc3MgY29uZmlndXJh dGlvbi4KPiAKPiBXcmFwcGVycyBhcmUgYWxzbyBhZGRlZCBmb3IgdGhlIG1ldGFkYXRhX29wczoK PiBkbWFlbmdpbmVfZGVzY19hdHRhY2hfbWV0YWRhdGEoKQo+IGRtYWVuZ2luZV9kZXNjX2dldF9t ZXRhZGF0YV9wdHIoKQo+IGRtYWVuZ2luZV9kZXNjX3NldF9tZXRhZGF0YV9sZW4oKQo+IAo+IFNp Z25lZC1vZmYtYnk6IFBldGVyIFVqZmFsdXNpIDxwZXRlci51amZhbHVzaUB0aS5jb20+Cj4gLS0t Cj4gSGksCj4gCj4gc2luY2UgYXR0YWNobWVudHMgYXJlIGJvdW5jaW5nIGJhY2ssIEkgc2VuZCB0 aGUgcGF0Y2ggc2VwYXJhdGVseQo+IAo+IFJlZ2FyZHMsCj4gUGV0ZXIKPiAKPiAgaW5jbHVkZS9s aW51eC9kbWFlbmdpbmUuaCB8IDUwICsrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysr KysrKwo+ICAxIGZpbGUgY2hhbmdlZCwgNTAgaW5zZXJ0aW9ucygrKQo+IAo+IGRpZmYgLS1naXQg YS9pbmNsdWRlL2xpbnV4L2RtYWVuZ2luZS5oIGIvaW5jbHVkZS9saW51eC9kbWFlbmdpbmUuaAo+ IGluZGV4IDUxZmJiODYxZTg0Yi4uYWM0MmFjZTM2YWEzIDEwMDY0NAo+IC0tLSBhL2luY2x1ZGUv bGludXgvZG1hZW5naW5lLmgKPiArKysgYi9pbmNsdWRlL2xpbnV4L2RtYWVuZ2luZS5oCj4gQEAg LTQ5MSw2ICs0OTEsMTggQEAgc3RydWN0IGRtYWVuZ2luZV91bm1hcF9kYXRhIHsKPiAgCWRtYV9h ZGRyX3QgYWRkclswXTsKPiAgfTsKPiAgCj4gK3N0cnVjdCBkbWFfYXN5bmNfdHhfZGVzY3JpcHRv cjsKPiArCj4gK3N0cnVjdCBkbWFfZGVzY3JpcHRvcl9tZXRhZGF0YV9vcHMgewo+ICsJaW50ICgq YXR0YWNoKShzdHJ1Y3QgZG1hX2FzeW5jX3R4X2Rlc2NyaXB0b3IgKmRlc2MsIHZvaWQgKmRhdGEs Cj4gKwkJICAgICAgc2l6ZV90IGxlbik7CgpIb3cgZG9lcyBvbmUgZGV0YWNoPyBXaGVuIHNob3Vs ZCB0aGUgY2xpZW50IGZyZWUgdXAgdGhlIG1lbW9yeSwgSU9XIHdoZW4KZG9lcyBkbWEgZHJpdmVy IGRyb3AgcmVmIHRvIGRhdGEuCgo+ICsKPiArCXZvaWQgKigqZ2V0X3B0cikoc3RydWN0IGRtYV9h c3luY190eF9kZXNjcmlwdG9yICpkZXNjLAo+ICsJCQkgc2l6ZV90ICpwYXlsb2FkX2xlbiwgc2l6 ZV90ICptYXhfbGVuKTsKCnNvIHdoYXQgaXMgdGhpcyBzdXBwb3NlZCB0byBkby4uPwoKPiArCWlu dCAoKnNldF9sZW4pKHN0cnVjdCBkbWFfYXN5bmNfdHhfZGVzY3JpcHRvciAqZGVzYywKPiArCQkg ICAgICAgc2l6ZV90IHBheWxvYWRfbGVuKTsKCmF0dGFjaCBhbHJlYWR5IGhhcyBsZW5ndGgsIHNv IGhvdyBkb2VzIHRoaXMgaGVscD8KCj4gK307Cj4gKwo+ICAvKioKPiAgICogc3RydWN0IGRtYV9h c3luY190eF9kZXNjcmlwdG9yIC0gYXN5bmMgdHJhbnNhY3Rpb24gZGVzY3JpcHRvcgo+ICAgKiAt LS1kbWEgZ2VuZXJpYyBvZmZsb2FkIGZpZWxkcy0tLQo+IEBAIC01MjAsNiArNTMyLDcgQEAgc3Ry dWN0IGRtYV9hc3luY190eF9kZXNjcmlwdG9yIHsKPiAgCWRtYV9hc3luY190eF9jYWxsYmFja19y ZXN1bHQgY2FsbGJhY2tfcmVzdWx0Owo+ICAJdm9pZCAqY2FsbGJhY2tfcGFyYW07Cj4gIAlzdHJ1 Y3QgZG1hZW5naW5lX3VubWFwX2RhdGEgKnVubWFwOwo+ICsJc3RydWN0IGRtYV9kZXNjcmlwdG9y X21ldGFkYXRhX29wcyAqbWV0YWRhdGFfb3BzOwo+ICAjaWZkZWYgQ09ORklHX0FTWU5DX1RYX0VO QUJMRV9DSEFOTkVMX1NXSVRDSAo+ICAJc3RydWN0IGRtYV9hc3luY190eF9kZXNjcmlwdG9yICpu ZXh0Owo+ICAJc3RydWN0IGRtYV9hc3luY190eF9kZXNjcmlwdG9yICpwYXJlbnQ7Cj4gQEAgLTkz Miw2ICs5NDUsNDMgQEAgc3RhdGljIGlubGluZSBzdHJ1Y3QgZG1hX2FzeW5jX3R4X2Rlc2NyaXB0 b3IgKmRtYWVuZ2luZV9wcmVwX2RtYV9tZW1jcHkoCj4gIAkJCQkJCSAgICBsZW4sIGZsYWdzKTsK PiAgfQo+ICAKPiArc3RhdGljIGlubGluZSBpbnQgZG1hZW5naW5lX2Rlc2NfYXR0YWNoX21ldGFk YXRhKAo+ICsJCXN0cnVjdCBkbWFfYXN5bmNfdHhfZGVzY3JpcHRvciAqZGVzYywgdm9pZCAqZGF0 YSwgc2l6ZV90IGxlbikKPiArewo+ICsJaWYgKCFkZXNjKQo+ICsJCXJldHVybiAwOwo+ICsKPiAr CWlmICghZGVzYy0+bWV0YWRhdGFfb3BzIHx8ICFkZXNjLT5tZXRhZGF0YV9vcHMtPmF0dGFjaCkK PiArCQlyZXR1cm4gLUVOT1RTVVBQOwo+ICsKPiArCXJldHVybiBkZXNjLT5tZXRhZGF0YV9vcHMt PmF0dGFjaChkZXNjLCBkYXRhLCBsZW4pOwo+ICt9Cj4gKwo+ICtzdGF0aWMgaW5saW5lIHZvaWQg KmRtYWVuZ2luZV9kZXNjX2dldF9tZXRhZGF0YV9wdHIoCj4gKwkJc3RydWN0IGRtYV9hc3luY190 eF9kZXNjcmlwdG9yICpkZXNjLCBzaXplX3QgKnBheWxvYWRfbGVuLAo+ICsJCXNpemVfdCAqbWF4 X2xlbikKPiArewo+ICsJaWYgKCFkZXNjKQo+ICsJCXJldHVybiBOVUxMOwo+ICsKPiArCWlmICgh ZGVzYy0+bWV0YWRhdGFfb3BzIHx8ICFkZXNjLT5tZXRhZGF0YV9vcHMtPmdldF9wdHIpCj4gKwkJ cmV0dXJuIEVSUl9QVFIoLUVOT1RTVVBQKTsKPiArCj4gKwlyZXR1cm4gZGVzYy0+bWV0YWRhdGFf b3BzLT5nZXRfcHRyKGRlc2MsIHBheWxvYWRfbGVuLCBtYXhfbGVuKTsKPiArfQo+ICsKPiArc3Rh dGljIGlubGluZSBpbnQgZG1hZW5naW5lX2Rlc2Nfc2V0X21ldGFkYXRhX2xlbigKPiArCQlzdHJ1 Y3QgZG1hX2FzeW5jX3R4X2Rlc2NyaXB0b3IgKmRlc2MsIHNpemVfdCBwYXlsb2FkX2xlbikKPiAr ewo+ICsJaWYgKCFkZXNjKQo+ICsJCXJldHVybiAwOwo+ICsKPiArCWlmICghZGVzYy0+bWV0YWRh dGFfb3BzIHx8ICFkZXNjLT5tZXRhZGF0YV9vcHMtPnNldF9sZW4pCj4gKwkJcmV0dXJuIC1FTk9U U1VQUDsKPiArCj4gKwlyZXR1cm4gZGVzYy0+bWV0YWRhdGFfb3BzLT5zZXRfbGVuKGRlc2MsIHBh eWxvYWRfbGVuKTsKPiArfQo+ICsKPiAgLyoqCj4gICAqIGRtYWVuZ2luZV90ZXJtaW5hdGVfYWxs KCkgLSBUZXJtaW5hdGUgYWxsIGFjdGl2ZSBETUEgdHJhbnNmZXJzCj4gICAqIEBjaGFuOiBUaGUg Y2hhbm5lbCBmb3Igd2hpY2ggdG8gdGVybWluYXRlIHRoZSB0cmFuc2ZlcnMKPiAtLSAKPiBQZXRl cgo+IAo+IFRleGFzIEluc3RydW1lbnRzIEZpbmxhbmQgT3ksIFBvcmtrYWxhbmthdHUgMjIsIDAw MTgwIEhlbHNpbmtpLgo+IFktdHVubnVzL0J1c2luZXNzIElEOiAwNjE1NTIxLTQuIEtvdGlwYWlr a2EvRG9taWNpbGU6IEhlbHNpbmtpCj4gCj4gLS0KPiBUbyB1bnN1YnNjcmliZSBmcm9tIHRoaXMg bGlzdDogc2VuZCB0aGUgbGluZSAidW5zdWJzY3JpYmUgZG1hZW5naW5lIiBpbgo+IHRoZSBib2R5 IG9mIGEgbWVzc2FnZSB0byBtYWpvcmRvbW9Admdlci5rZXJuZWwub3JnCj4gTW9yZSBtYWpvcmRv bW8gaW5mbyBhdCAgaHR0cDovL3ZnZXIua2VybmVsLm9yZy9tYWpvcmRvbW8taW5mby5odG1sCg== From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.6 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,MAILING_LIST_MULTI,SPF_PASS,T_DKIMWL_WL_HIGH,URIBL_BLOCKED, USER_AGENT_MUTT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 39E74C3279B for ; Tue, 10 Jul 2018 05:52:47 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id E3168208E1 for ; Tue, 10 Jul 2018 05:52:46 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=kernel.org header.i=@kernel.org header.b="Vgmyzni2" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org E3168208E1 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751418AbeGJFwl (ORCPT ); Tue, 10 Jul 2018 01:52:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:36038 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751058AbeGJFwj (ORCPT ); Tue, 10 Jul 2018 01:52:39 -0400 Received: from localhost (unknown [106.200.232.130]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5AC5020881; Tue, 10 Jul 2018 05:52:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1531201959; bh=YIBjc5TiKWUYyZUl1Agnnf4BWMjT8pvgVMlK0xLkOzM=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=Vgmyzni2nRWBWmzXJ1dbA/BccCooAszyo5ZWMa+s5tbk2gUlRZLdvkOPjSeYyOTPe xmMM0tRMVoqmTvi1ZHoat7TZLdzd4adxA1JZBd4c5Oejb+ZZp3Ee8fVILbgo3f+K1G RrIqRjEKbrwCvroT8JioxTX8573bSbw6kUmEwk/8= Date: Tue, 10 Jul 2018 11:22:30 +0530 From: Vinod To: Peter Ujfalusi Cc: radheys@xilinx.com, vinod.koul@intel.com, lars@metafoo.de, michal.simek@xilinx.com, linux-kernel@vger.kernel.org, dmaengine@vger.kernel.org, dan.j.williams@intel.com, appanad@xilinx.com, linux-arm-kernel@lists.infradead.org Subject: Re: [RFC] dmaengine: Add metadat_ops for dma_async_tx_descriptor Message-ID: <20180710055230.GB3219@vkoul-mobl> References: <32208a9c-2b15-d345-1432-f1e387531f9b@ti.com> <20180601102429.16429-1-peter.ujfalusi@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180601102429.16429-1-peter.ujfalusi@ti.com> User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hey Peter, Sorry for late response on this.. On 01-06-18, 13:24, Peter Ujfalusi wrote: > If the DMA supports per descriptor metadata it can implement the attach, > get_ptr/set_len callbacks. > > Client drivers must only use either attach or get_ptr/set_len to avoid > miss configuration. > > Wrappers are also added for the metadata_ops: > dmaengine_desc_attach_metadata() > dmaengine_desc_get_metadata_ptr() > dmaengine_desc_set_metadata_len() > > Signed-off-by: Peter Ujfalusi > --- > Hi, > > since attachments are bouncing back, I send the patch separately > > Regards, > Peter > > include/linux/dmaengine.h | 50 +++++++++++++++++++++++++++++++++++++++ > 1 file changed, 50 insertions(+) > > diff --git a/include/linux/dmaengine.h b/include/linux/dmaengine.h > index 51fbb861e84b..ac42ace36aa3 100644 > --- a/include/linux/dmaengine.h > +++ b/include/linux/dmaengine.h > @@ -491,6 +491,18 @@ struct dmaengine_unmap_data { > dma_addr_t addr[0]; > }; > > +struct dma_async_tx_descriptor; > + > +struct dma_descriptor_metadata_ops { > + int (*attach)(struct dma_async_tx_descriptor *desc, void *data, > + size_t len); How does one detach? When should the client free up the memory, IOW when does dma driver drop ref to data. > + > + void *(*get_ptr)(struct dma_async_tx_descriptor *desc, > + size_t *payload_len, size_t *max_len); so what is this supposed to do..? > + int (*set_len)(struct dma_async_tx_descriptor *desc, > + size_t payload_len); attach already has length, so how does this help? > +}; > + > /** > * struct dma_async_tx_descriptor - async transaction descriptor > * ---dma generic offload fields--- > @@ -520,6 +532,7 @@ struct dma_async_tx_descriptor { > dma_async_tx_callback_result callback_result; > void *callback_param; > struct dmaengine_unmap_data *unmap; > + struct dma_descriptor_metadata_ops *metadata_ops; > #ifdef CONFIG_ASYNC_TX_ENABLE_CHANNEL_SWITCH > struct dma_async_tx_descriptor *next; > struct dma_async_tx_descriptor *parent; > @@ -932,6 +945,43 @@ static inline struct dma_async_tx_descriptor *dmaengine_prep_dma_memcpy( > len, flags); > } > > +static inline int dmaengine_desc_attach_metadata( > + struct dma_async_tx_descriptor *desc, void *data, size_t len) > +{ > + if (!desc) > + return 0; > + > + if (!desc->metadata_ops || !desc->metadata_ops->attach) > + return -ENOTSUPP; > + > + return desc->metadata_ops->attach(desc, data, len); > +} > + > +static inline void *dmaengine_desc_get_metadata_ptr( > + struct dma_async_tx_descriptor *desc, size_t *payload_len, > + size_t *max_len) > +{ > + if (!desc) > + return NULL; > + > + if (!desc->metadata_ops || !desc->metadata_ops->get_ptr) > + return ERR_PTR(-ENOTSUPP); > + > + return desc->metadata_ops->get_ptr(desc, payload_len, max_len); > +} > + > +static inline int dmaengine_desc_set_metadata_len( > + struct dma_async_tx_descriptor *desc, size_t payload_len) > +{ > + if (!desc) > + return 0; > + > + if (!desc->metadata_ops || !desc->metadata_ops->set_len) > + return -ENOTSUPP; > + > + return desc->metadata_ops->set_len(desc, payload_len); > +} > + > /** > * dmaengine_terminate_all() - Terminate all active DMA transfers > * @chan: The channel for which to terminate the transfers > -- > Peter > > Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. > Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki > > -- > To unsubscribe from this list: send the line "unsubscribe dmaengine" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html -- ~Vinod From mboxrd@z Thu Jan 1 00:00:00 1970 From: vkoul@kernel.org (Vinod) Date: Tue, 10 Jul 2018 11:22:30 +0530 Subject: [RFC] dmaengine: Add metadat_ops for dma_async_tx_descriptor In-Reply-To: <20180601102429.16429-1-peter.ujfalusi@ti.com> References: <32208a9c-2b15-d345-1432-f1e387531f9b@ti.com> <20180601102429.16429-1-peter.ujfalusi@ti.com> Message-ID: <20180710055230.GB3219@vkoul-mobl> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org Hey Peter, Sorry for late response on this.. On 01-06-18, 13:24, Peter Ujfalusi wrote: > If the DMA supports per descriptor metadata it can implement the attach, > get_ptr/set_len callbacks. > > Client drivers must only use either attach or get_ptr/set_len to avoid > miss configuration. > > Wrappers are also added for the metadata_ops: > dmaengine_desc_attach_metadata() > dmaengine_desc_get_metadata_ptr() > dmaengine_desc_set_metadata_len() > > Signed-off-by: Peter Ujfalusi > --- > Hi, > > since attachments are bouncing back, I send the patch separately > > Regards, > Peter > > include/linux/dmaengine.h | 50 +++++++++++++++++++++++++++++++++++++++ > 1 file changed, 50 insertions(+) > > diff --git a/include/linux/dmaengine.h b/include/linux/dmaengine.h > index 51fbb861e84b..ac42ace36aa3 100644 > --- a/include/linux/dmaengine.h > +++ b/include/linux/dmaengine.h > @@ -491,6 +491,18 @@ struct dmaengine_unmap_data { > dma_addr_t addr[0]; > }; > > +struct dma_async_tx_descriptor; > + > +struct dma_descriptor_metadata_ops { > + int (*attach)(struct dma_async_tx_descriptor *desc, void *data, > + size_t len); How does one detach? When should the client free up the memory, IOW when does dma driver drop ref to data. > + > + void *(*get_ptr)(struct dma_async_tx_descriptor *desc, > + size_t *payload_len, size_t *max_len); so what is this supposed to do..? > + int (*set_len)(struct dma_async_tx_descriptor *desc, > + size_t payload_len); attach already has length, so how does this help? > +}; > + > /** > * struct dma_async_tx_descriptor - async transaction descriptor > * ---dma generic offload fields--- > @@ -520,6 +532,7 @@ struct dma_async_tx_descriptor { > dma_async_tx_callback_result callback_result; > void *callback_param; > struct dmaengine_unmap_data *unmap; > + struct dma_descriptor_metadata_ops *metadata_ops; > #ifdef CONFIG_ASYNC_TX_ENABLE_CHANNEL_SWITCH > struct dma_async_tx_descriptor *next; > struct dma_async_tx_descriptor *parent; > @@ -932,6 +945,43 @@ static inline struct dma_async_tx_descriptor *dmaengine_prep_dma_memcpy( > len, flags); > } > > +static inline int dmaengine_desc_attach_metadata( > + struct dma_async_tx_descriptor *desc, void *data, size_t len) > +{ > + if (!desc) > + return 0; > + > + if (!desc->metadata_ops || !desc->metadata_ops->attach) > + return -ENOTSUPP; > + > + return desc->metadata_ops->attach(desc, data, len); > +} > + > +static inline void *dmaengine_desc_get_metadata_ptr( > + struct dma_async_tx_descriptor *desc, size_t *payload_len, > + size_t *max_len) > +{ > + if (!desc) > + return NULL; > + > + if (!desc->metadata_ops || !desc->metadata_ops->get_ptr) > + return ERR_PTR(-ENOTSUPP); > + > + return desc->metadata_ops->get_ptr(desc, payload_len, max_len); > +} > + > +static inline int dmaengine_desc_set_metadata_len( > + struct dma_async_tx_descriptor *desc, size_t payload_len) > +{ > + if (!desc) > + return 0; > + > + if (!desc->metadata_ops || !desc->metadata_ops->set_len) > + return -ENOTSUPP; > + > + return desc->metadata_ops->set_len(desc, payload_len); > +} > + > /** > * dmaengine_terminate_all() - Terminate all active DMA transfers > * @chan: The channel for which to terminate the transfers > -- > Peter > > Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. > Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki > > -- > To unsubscribe from this list: send the line "unsubscribe dmaengine" in > the body of a message to majordomo at vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html -- ~Vinod