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

ngen: workaround for PVC SWSB HW bug #2443

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open

Conversation

petercad
Copy link
Contributor

Closes MFDNN-12992. Introduces a workaround for a PVC HW bug related to SWSB dependencies on send instruction src operands in the presence of heavy double precision usage. This is not an expected use case for oneDNN, but could theoretically occur if another f64-heavy kernel is running in parallel.

The workaround is carefully written to minimize performance impacts, but if performance impacts are still too high, we can enable the WA on an as-needs basis.

@petercad petercad requested a review from a team as a code owner January 17, 2025 20:06
@petercad
Copy link
Contributor Author

make test
disable device_cpu
disable benchdnn_all
enable benchdnn_matmul
disable arch_xe-lpg
disable arch_xe-hpg-dg2
disable arch_xe-hpg-atsm
disable arch_xe2-lpg
disable arch_xe2-hpg-bmg

@petercad
Copy link
Contributor Author

make test perf-gpu
set primitive=matmul ip
disable arch_xe-hpg-atsm
disable arch_xe-hpg-dg2
disable arch_xe2-lpg
disable arch_xe2-hpg-bmg

@petercad
Copy link
Contributor Author

make test perf-gpu
set primitive=matmul ip conv
disable arch_xe-hpg-atsm
disable arch_xe-hpg-dg2
disable arch_xe2-lpg
disable arch_xe2-hpg-bmg

// Handle PVC HW bug with WAR dependencies on send instructions.
PVCWARWA pww;
if (pvcWARWA && !regions[0].empty() && computeSWSB)
pww = analyzePVCWARWA(hw, program, bb, phase, consumeOp, pvcWARWADeps);
Copy link
Contributor

Choose a reason for hiding this comment

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

Can we move this if statement into analyzePVCWARWA to prevent invalid use of that function?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Sure, I can do that.

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.

3 participants