Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Clarify the definition of prerequisites to commands #923

Merged
merged 2 commits into from
Jul 2, 2024

Conversation

kpet
Copy link
Contributor

@kpet kpet commented May 9, 2023

  • Reword the first source of prerequisites so the wording is symmetrical with respect to the others (i.e. the first/second/third ...).
  • Broaden the first source of prerequisites to cover all implicit dependencies and provide an exhaustive list of how they arise: either because of barriers or because of ordering in in-order command-queues.

Change-Id: Ic464066261fe13756347bafb4878cd6ffb5a8427

@kpet kpet requested a review from bashbaug May 9, 2023 18:30
Comment on lines 204 to 205
** Commands enqueued after a command-queue barrier have all commands enqueued
before the barrier as prerequisites.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is one of the more confusing parts of the OpenCL spec, and this isn't common, but strictly speaking I don't think this is true: if a barrier is in an out-of-order queue, and if the barrier has an explicit event wait list, then the barrier will only wait for the commands described by the event wait list commands to complete, and subsequent commands will only wait for the barrier to complete. This means that other commands enqueued before the barrier, but that the barrier did not wait on, may still be executing.

The easiest way to describe this may be to describe dependency on the barrier itself, not on the commands before the barrier, something like:

  • Commands enqueued after a command-queue barrier have an implicit dependency on the command-queue barrier as a prerequesite.

Or, slightly more verbose:

  • Commands enqueued after a command-queue barrier have an implicit dependency on the completion of the preceding command-queue barrier as a prerequesite.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree with your description of what the behaviour should be. This was meant to cover barriers with no explicit prerequisites, good catch. I've updated the description.

I don't think your proposed "dependency on the barrier" wording (paraphrasing) works well. We'd still need to describe what a barrier depends on and that is only done in the description for clEnqueueBarrierWithWaitList and not in terms of prerequisites.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm fine with the updated text and this is a definite improvement over what is currently in the spec, but FWIW I do quite like the "dependency on the barrier" wording. Consider a case like the following (pseudocode):

clEnqueueNDRangeKernel(A);
clEnqueueNDRangeKernel(B);
clEnqueueNDRangeKernel(C);
clEnqueueBarrier(wait on {A, B});
clEnqueueNDRangeKernel(D);

Do we agree:

  1. Kernels A, B, and C have no implicit or explicit prerequisites, so they may execute anytime and in any order, and may overlap execution.
  2. The barrier will not complete until kernels A and B are complete because of the explicit dependencies specified by the event wait list.
  3. Kernel D has the barrier as an implicit prerequisite, hence a transitive dependency on kernels A and B, even though it has no explicit prerequisites. There is no dependency between kernels C and D though, so C and D may overlap execution.

If so, I think (2) is covered by "the second source of prerequisites", but I'm not sure how (3) would be covered by the text in this PR.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  1. Yes.
  2. Yes.
  3. Yes.

I've returned to this with a fresher mind and definitely agree your suggestion of describing implicit prerequisites in terms on dependencies on barriers is better. I've tweaked the PR to reflect that which I believe covers your case 3.
PTAL.

api/opencl_architecture.asciidoc Outdated Show resolved Hide resolved
- Reword the first source of prerequisites so the wording is symmetrical
  with respect to the others (i.e. the first/second/third ...).
- Broaden the first source of prerequisites to cover all implicit
  dependencies and provide an exhaustive list of how they arise: either
  because of barriers or because of ordering in in-order command-queues.

Signed-off-by: Kevin Petit <[email protected]>
Change-Id: Ic464066261fe13756347bafb4878cd6ffb5a8427
@kpet kpet force-pushed the in-order-pre-requisites branch from a021f65 to ed7293f Compare June 21, 2024 16:50
@kpet kpet requested a review from bashbaug June 21, 2024 16:53
api/opencl_architecture.asciidoc Outdated Show resolved Hide resolved
api/opencl_architecture.asciidoc Outdated Show resolved Hide resolved
@neiltrevett neiltrevett merged commit f50c458 into KhronosGroup:main Jul 2, 2024
2 checks passed
@kpet kpet deleted the in-order-pre-requisites branch July 2, 2024 16:23
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants