Refactor job API: add JobExecutionContext, update tests

Major breaking change: job interfaces now use JobExecutionContext
instead of threadIndex, enabling thread-aware and dynamic job
dispatching. Updated all job system, SPMD, and test code to match.
Collections improved with new methods and clearer enumerators.
Renamed IJobScheduler.WaitComplete to Wait. Incremented project
versions. Includes bug fixes, documentation, and style updates.
This commit is contained in:
2026-03-04 11:43:39 +09:00
parent b9ca71834f
commit 37d548085e
31 changed files with 652 additions and 207 deletions

View File

@@ -0,0 +1,35 @@
using Misaki.HighPerformance.Jobs;
using Misaki.HighPerformance.LowLevel.Collections;
namespace Misaki.HighPerformance.Test.Jobs;
internal struct JobDispatchingJob : IJobParallelFor
{
public UnsafeArray<UnsafeArray<int>> data;
public UnsafeList<JobHandle>.ParallelWriter handles;
private struct InnerJob : IJobParallelFor
{
public UnsafeArray<int> data;
public void Execute(int loopIndex, ref readonly JobExecutionContext ctx)
{
ref var value = ref data[loopIndex];
value *= 2;
}
}
public void Execute(int loopIndex, ref readonly JobExecutionContext ctx)
{
if (loopIndex % 2 == 0)
{
var innerJob = new InnerJob
{
data = data[loopIndex]
};
var handle = ctx.JobScheduler.ScheduleParallelFor(in innerJob, data[loopIndex].Length, 64, ctx.ThreadIndex);
handles.AddNoResize(handle);
}
}
}

View File

@@ -13,7 +13,7 @@ internal unsafe struct NoiseJobVectorFor : IJobParallelFor
public int width;
public int height;
public void Execute(int loopIndex, int threadIndex)
public void Execute(int loopIndex, ref readonly JobExecutionContext ctx)
{
var x = loopIndex % width;
var y = loopIndex / height;
@@ -65,7 +65,7 @@ internal unsafe struct NoiseJobVector : IJobParallel
return float.Lerp(float.Lerp(d00, d10, fp.Y), float.Lerp(d01, d11, fp.Y), fp.X);
}
public void Execute(int startIndex, int endIndex, int threadIndex)
public void Execute(int startIndex, int endIndex, ref readonly JobExecutionContext ctx)
{
for (int i = startIndex; i < endIndex; i++)
{
@@ -118,7 +118,7 @@ internal unsafe struct NoiseJobMath : IJobParallel
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public void Execute(int startIndex, int endIndex, int threadIndex)
public void Execute(int startIndex, int endIndex, ref readonly JobExecutionContext ctx)
{
for (var i = startIndex; i < endIndex; i++)
{
@@ -199,7 +199,7 @@ internal unsafe struct NoiseJobMathV : IJobParallel
return lerpY1 + (lerpY2 - lerpY1) * uX;
}
public void Execute(int startIndex, int endIndex, int threadIndex)
public void Execute(int startIndex, int endIndex, ref readonly JobExecutionContext ctx)
{
for (int i = startIndex; i < endIndex; i++)
{
@@ -291,7 +291,7 @@ internal unsafe struct NoiseJobMathSPMD : IJobSPMD<float>
return T.Lerp(T.Lerp(d00, d10, uY), T.Lerp(d01, d11, uY), uX);
}
public readonly void Execute<TLane>(int baseIndex, int threadIndex)
public readonly void Execute<TLane>(int baseIndex, ref readonly JobExecutionContext ctx)
where TLane : ISPMD<TLane, float>
{
var indices = TLane.Sequence(baseIndex, 1f);