From: fengchengwen <fengchengwen@huawei.com>
To: Bruce Richardson <bruce.richardson@intel.com>
Cc: <thomas@monjalon.net>, <ferruh.yigit@intel.com>, <dev@dpdk.org>,
<nipun.gupta@nxp.com>, <hemant.agrawal@nxp.com>,
<maxime.coquelin@redhat.com>, <honnappa.nagarahalli@arm.com>,
<jerinj@marvell.com>, <david.marchand@redhat.com>,
<jerinjacobk@gmail.com>
Subject: Re: [dpdk-dev] [RFC PATCH] dmadev: introduce DMA device library
Date: Wed, 16 Jun 2021 17:41:45 +0800 [thread overview]
Message-ID: <a5dc8da0-bfb6-db19-3567-ecb912c4c6ef@huawei.com> (raw)
In-Reply-To: <YMjXilFHjCxQ9ViD@bricha3-MOBL.ger.corp.intel.com>
On 2021/6/16 0:38, Bruce Richardson wrote:
> On Tue, Jun 15, 2021 at 09:22:07PM +0800, Chengwen Feng wrote:
>> This patch introduces 'dmadevice' which is a generic type of DMA
>> device.
>>
>> The APIs of dmadev library exposes some generic operations which can
>> enable configuration and I/O with the DMA devices.
>>
>> Signed-off-by: Chengwen Feng <fengchengwen@huawei.com>
>> ---
> Thanks for sending this.
>
> Of most interest to me right now are the key data-plane APIs. While we are
> still in the prototyping phase, below is a draft of what we are thinking
> for the key enqueue/perform_ops/completed_ops APIs.
>
> Some key differences I note in below vs your original RFC:
> * Use of void pointers rather than iova addresses. While using iova's makes
> sense in the general case when using hardware, in that it can work with
> both physical addresses and virtual addresses, if we change the APIs to use
> void pointers instead it will still work for DPDK in VA mode, while at the
> same time allow use of software fallbacks in error cases, and also a stub
> driver than uses memcpy in the background. Finally, using iova's makes the
> APIs a lot more awkward to use with anything but mbufs or similar buffers
> where we already have a pre-computed physical address.
The iova is an hint to application, and widely used in DPDK.
If switch to void, how to pass the address (iova or just va ?)
this may introduce implementation dependencies here.
Or always pass the va, and the driver performs address translation, and this
translation may cost too much cpu I think.
> * Use of id values rather than user-provided handles. Allowing the user/app
> to manage the amount of data stored per operation is a better solution, I
> feel than proscribing a certain about of in-driver tracking. Some apps may
> not care about anything other than a job being completed, while other apps
> may have significant metadata to be tracked. Taking the user-context
> handles out of the API also makes the driver code simpler.
The user-provided handle was mainly used to simply application implementation,
It provides the ability to quickly locate contexts.
The "use of id values" seem like the dma_cookie of Linux DMA engine framework,
user will get a unique dma_cookie after calling dmaengine_submit(), and then
could use it to call dma_async_is_tx_complete() to get completion status.
How about define the copy prototype as following:
dma_cookie_t rte_dmadev_copy(uint16_t dev_id, xxx)
while the dma_cookie_t is int32 and is monotonically increasing, when >=0 mean
enqueue successful else fail.
when complete the dmadev will return latest completed dma_cookie, and the
application could use the dma_cookie to quick locate contexts.
> * I've kept a single combined API for completions, which differs from the
> separate error handling completion API you propose. I need to give the
> two function approach a bit of thought, but likely both could work. If we
> (likely) never expect failed ops, then the specifics of error handling
> should not matter that much.
The rte_ioat_completed_ops API is too complex, and consider some applications
may never copy fail, so split them as two API.
It's indeed not friendly to other scenarios that always require error handling.
I prefer use completed operations number as return value other than the ID so
that application could simple judge whether have new completed operations, and
the new prototype:
uint16_t rte_dmadev_completed(uint16_t dev_id, dma_cookie_t *cookie, uint32_t *status, uint16_t max_status, uint16_t *num_fails);
1) for normal case which never expect failed ops:
just call: ret = rte_dmadev_completed(dev_id, &cookie, NULL, 0, NULL);
2) for other case:
ret = rte_dmadev_completed(dev_id, &cookie, &status, max_status, &fails);
at this point the fails <= ret <= max_status
>
> For the rest, the control / setup APIs are likely to be rather
> uncontroversial, I suspect. However, I think that rather than xstats APIs,
> the library should first provide a set of standardized stats like ethdev
> does. If driver-specific stats are needed, we can add xstats later to the
> API.
Agree, will fix in v2
>
> Appreciate your further thoughts on this, thanks.
>
> Regards,
> /Bruce
>
> /**
> * @warning
> * @b EXPERIMENTAL: this API may change without prior notice.
> *
> * Enqueue a copy operation onto the DMA device
> *
> * This queues up a copy operation to be performed by hardware, but does not
> * trigger hardware to begin that operation.
> *
> * @param dev_id
> * The dmadev device id of the DMA instance
> * @param src
> * The source buffer
> * @param dst
> * The destination buffer
> * @param length
> * The length of the data to be copied
> * @return
> * - On success, id (uint16_t) of job enqueued
> * - On failure, negative error code
> */
> static inline int
> __rte_experimental
> rte_dmadev_enqueue_copy(uint16_t dev_id, void * src, void * dst, unsigned int length);
>
> /**
> * @warning
> * @b EXPERIMENTAL: this API may change without prior notice.
> *
> * Trigger hardware to begin performing enqueued operations
> *
> * This API is used to write the "doorbell" to the hardware to trigger it
> * to begin the operations previously enqueued by e.g. rte_dmadev_enqueue_copy()
> *
> * @param dev_id
> * The dmadev device id of the DMA instance
> * @return
> * 0 on success, negative errno on error
> */
> static inline int
> __rte_experimental
> rte_dmadev_perform_ops(uint16_t dev_id);
>
> /**
> * @warning
> * @b EXPERIMENTAL: this API may change without prior notice.
> *
> * Returns details of operations that have been completed
> *
> * In the normal case of no failures in hardware performing the requested jobs,
> * the return value is the ID of the last completed operation, and
> * "num_reported_status" is 0.
> *
> * If errors have occured the status of "num_reported_status" (<= "max_status")
> * operations are reported in the "status" array, with the return value being
> * the ID of the last operation reported in that array.
> *
> * @param dev_id
> * The dmadev device id of the DMA instance
> * @param max_status
> * The number of entries which can fit in the status arrays, i.e. max number
> * of completed operations to report.
> * @param[out] status
> * Array to hold the status of each completed operation.
> * A value of RTE_DMA_OP_SKIPPED implies an operation was not attempted,
> * and any other non-zero value indicates operation failure.
> * @param[out] num_reported_status
> * Returns the number of elements in status. If this value is returned as
> * zero (the expected case), the status array will not have been modified
> * by the function and need not be checked by software
> * @return
> * On success, ID of the last completed/reported operation.
> * Negative errno on error, with all parameters unmodified.
> */
> static inline int
> __rte_experimental
> rte_dmadev_completed_ops(uint16_t dev_id, uint8_t max_status,
> uint32_t *status, uint8_t *num_reported_status);
>
>
> .
>
next prev parent reply other threads:[~2021-06-16 9:42 UTC|newest]
Thread overview: 79+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-06-15 13:22 Chengwen Feng
2021-06-15 16:38 ` Bruce Richardson
2021-06-16 7:09 ` Morten Brørup
2021-06-16 10:17 ` fengchengwen
2021-06-16 12:09 ` Morten Brørup
2021-06-16 13:06 ` Bruce Richardson
2021-06-16 14:37 ` Jerin Jacob
2021-06-17 9:15 ` Bruce Richardson
2021-06-18 5:52 ` Jerin Jacob
2021-06-18 9:41 ` fengchengwen
2021-06-22 17:25 ` Jerin Jacob
2021-06-23 3:30 ` fengchengwen
2021-06-23 7:21 ` Jerin Jacob
2021-06-23 9:37 ` Bruce Richardson
2021-06-23 11:40 ` Jerin Jacob
2021-06-23 14:19 ` Bruce Richardson
2021-06-24 6:49 ` Jerin Jacob
2021-06-23 9:41 ` Bruce Richardson
2021-06-23 10:10 ` Morten Brørup
2021-06-23 11:46 ` Jerin Jacob
2021-06-23 14:22 ` Bruce Richardson
2021-06-18 9:55 ` Bruce Richardson
2021-06-22 17:31 ` Jerin Jacob
2021-06-22 19:17 ` Bruce Richardson
2021-06-23 7:00 ` Jerin Jacob
2021-06-16 9:41 ` fengchengwen [this message]
2021-06-16 17:31 ` Bruce Richardson
2021-06-16 18:08 ` Jerin Jacob
2021-06-16 19:13 ` Bruce Richardson
2021-06-17 7:42 ` Jerin Jacob
2021-06-17 8:00 ` Bruce Richardson
2021-06-18 5:16 ` Jerin Jacob
2021-06-18 10:03 ` Bruce Richardson
2021-06-22 17:36 ` Jerin Jacob
2021-06-17 9:48 ` fengchengwen
2021-06-17 11:02 ` Bruce Richardson
2021-06-17 14:18 ` Bruce Richardson
2021-06-18 8:52 ` fengchengwen
2021-06-18 9:30 ` Bruce Richardson
2021-06-22 17:51 ` Jerin Jacob
2021-06-23 3:50 ` fengchengwen
2021-06-23 11:00 ` Jerin Jacob
2021-06-23 14:56 ` Bruce Richardson
2021-06-24 12:19 ` fengchengwen
2021-06-26 3:59 ` [dpdk-dev] dmadev discussion summary fengchengwen
2021-06-28 10:00 ` Bruce Richardson
2021-06-28 11:14 ` Ananyev, Konstantin
2021-06-28 12:53 ` Bruce Richardson
2021-07-02 13:31 ` fengchengwen
2021-07-01 15:01 ` Jerin Jacob
2021-07-01 16:33 ` Bruce Richardson
2021-07-02 7:39 ` Morten Brørup
2021-07-02 10:05 ` Bruce Richardson
2021-07-02 13:45 ` fengchengwen
2021-07-02 14:57 ` Morten Brørup
2021-07-03 0:32 ` fengchengwen
2021-07-03 8:53 ` Morten Brørup
2021-07-03 9:08 ` Jerin Jacob
2021-07-03 12:24 ` Morten Brørup
2021-07-04 7:43 ` Jerin Jacob
2021-07-05 10:28 ` Morten Brørup
2021-07-06 7:11 ` fengchengwen
2021-07-03 9:45 ` fengchengwen
2021-07-03 12:00 ` Morten Brørup
2021-07-04 7:34 ` Jerin Jacob
2021-07-02 7:07 ` Liang Ma
2021-07-02 13:59 ` fengchengwen
2021-06-24 7:03 ` [dpdk-dev] [RFC PATCH] dmadev: introduce DMA device library Jerin Jacob
2021-06-24 7:59 ` Morten Brørup
2021-06-24 8:05 ` Jerin Jacob
2021-06-23 5:34 ` Hu, Jiayu
2021-06-23 11:07 ` Jerin Jacob
2021-06-16 2:17 ` Wang, Haiyue
2021-06-16 8:04 ` Bruce Richardson
2021-06-16 8:16 ` Wang, Haiyue
2021-06-16 12:14 ` David Marchand
2021-06-16 13:11 ` Bruce Richardson
2021-06-16 16:48 ` Honnappa Nagarahalli
2021-06-16 19:10 ` Bruce Richardson
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=a5dc8da0-bfb6-db19-3567-ecb912c4c6ef@huawei.com \
--to=fengchengwen@huawei.com \
--cc=bruce.richardson@intel.com \
--cc=david.marchand@redhat.com \
--cc=dev@dpdk.org \
--cc=ferruh.yigit@intel.com \
--cc=hemant.agrawal@nxp.com \
--cc=honnappa.nagarahalli@arm.com \
--cc=jerinj@marvell.com \
--cc=jerinjacobk@gmail.com \
--cc=maxime.coquelin@redhat.com \
--cc=nipun.gupta@nxp.com \
--cc=thomas@monjalon.net \
/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;
as well as URLs for NNTP newsgroup(s).