The Linux Kernel Mailing List
 help / color / mirror / Atom feed
From: "Lynch, Nathan" <nathan.lynch@amd.com>
To: Frank Li <Frank.li@nxp.com>
Cc: Vinod Koul <vkoul@kernel.org>, Wei Huang <wei.huang2@amd.com>,
	Mario Limonciello <mario.limonciello@amd.com>,
	Bjorn Helgaas <bhelgaas@google.com>,
	Jonathan Cameron <jonathan.cameron@huawei.com>,
	Stephen Bates <Stephen.Bates@amd.com>,
	PradeepVineshReddy.Kodamati@amd.com, John.Kariuki@amd.com,
	linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org,
	dmaengine@vger.kernel.org
Subject: Re: [PATCH 11/23] dmaengine: sdxi: Add client context alloc and release APIs
Date: Mon, 11 May 2026 12:55:16 -0500	[thread overview]
Message-ID: <37fdf21a-3c6c-4b11-9b97-e84f86b702b3@amd.com> (raw)
In-Reply-To: <aeXhkIZgwGttlJB0@lizhi-Precision-Tower-5810>

Hi Frank,

Just following up on one thing as I prepare to post v2.

On 4/20/2026 3:19 AM, Frank Li wrote:
>> +/*
>> + * Allocate the context ID; link the context back to the device;
>> + * perform some final initialization of the context based on the ID
>> + * allocated; update the context tables.
>> + */
>> +static int register_cxt(struct sdxi_dev *sdxi, struct sdxi_cxt *cxt)
>> +{
>> +     int err;
>> +
>> +     CLASS(sdxi_alloc_cxt_id, slot)(sdxi, cxt);
>> +     if (slot.id < 0)
>> +             return slot.id;
> 
> I like use cleanup to do this. define error macro, like cleanup.h
> 
>  *      ACQUIRE(pci_dev_try, lock)(dev);
>  *      rc = ACQUIRE_ERR(pci_dev_try, &lock);
> 
> so hidden detail "id" in sdxi_alloc_cxt_id.
> 
> Or you can refer runtime pm method, save necceary information to "cxt"
> 
> DEFINE_GUARD_COND(pm_runtime_active, _try,
>                   pm_runtime_get_active(_T, RPM_TRANSPARENT), _RET == 0)
> 
>> +
>> +     cxt->sdxi = sdxi;
>> +     cxt->id = slot.id;
>> +     cxt->db = sdxi->dbs + slot.id * sdxi->db_stride;
>> +
>> +     err = sdxi_publish_cxt(cxt);
>> +     if (err)
>> +             return err;
>> +
>> +     take_sdxi_cxt_id(slot);
> 
> I undestand try to keep id to avoid call xa_erase. but it hidden too much
> detail.
> 
> If only one error branch, using cleanup here have not bring too much beneafit.
> 
> 
> Idealy logic
> 
>         id = __free(your_xa_erase) your_xa_alloc()
>         ...
>         ctx->id = no_free_ptr(id).

Non-pointer types tend to require a class for automatic cleanup AFAICT
but I think I get pretty close to this in v2. I also reworked the
context allocation logic to reserve IDs earlier.


           reply	other threads:[~2026-05-11 17:55 UTC|newest]

Thread overview: expand[flat|nested]  mbox.gz  Atom feed
 [parent not found: <aeXhkIZgwGttlJB0@lizhi-Precision-Tower-5810>]

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=37fdf21a-3c6c-4b11-9b97-e84f86b702b3@amd.com \
    --to=nathan.lynch@amd.com \
    --cc=Frank.li@nxp.com \
    --cc=John.Kariuki@amd.com \
    --cc=PradeepVineshReddy.Kodamati@amd.com \
    --cc=Stephen.Bates@amd.com \
    --cc=bhelgaas@google.com \
    --cc=dmaengine@vger.kernel.org \
    --cc=jonathan.cameron@huawei.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-pci@vger.kernel.org \
    --cc=mario.limonciello@amd.com \
    --cc=vkoul@kernel.org \
    --cc=wei.huang2@amd.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox