forked from intel/llvm
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpi_level_zero.cpp
More file actions
1256 lines (1048 loc) · 53.7 KB
/
pi_level_zero.cpp
File metadata and controls
1256 lines (1048 loc) · 53.7 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
//===-------- pi_level_zero.cpp - Level Zero Plugin --------------------==//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===------------------------------------------------------------------===//
/// \file pi_level_zero.cpp
/// Implementation of Level Zero Plugin.
///
/// \ingroup sycl_pi_level_zero
#include "pi_level_zero.hpp"
#include "ur_bindings.hpp"
// Defined in tracing.cpp
void enableZeTracing();
void disableZeTracing();
extern "C" {
// Forward declarations
decltype(piEventCreate) piEventCreate;
pi_result piPlatformsGet(pi_uint32 NumEntries, pi_platform *Platforms,
pi_uint32 *NumPlatforms) {
return pi2ur::piPlatformsGet(NumEntries, Platforms, NumPlatforms);
}
pi_result piPlatformGetInfo(pi_platform Platform, pi_platform_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
// To distinguish this L0 platform from Unified Runtime one.
if (ParamName == PI_PLATFORM_INFO_NAME) {
ReturnHelper ReturnValue(ParamValueSize, ParamValue, ParamValueSizeRet);
return ReturnValue("Intel(R) Level-Zero");
}
return pi2ur::piPlatformGetInfo(Platform, ParamName, ParamValueSize,
ParamValue, ParamValueSizeRet);
}
pi_result piextPlatformGetNativeHandle(pi_platform Platform,
pi_native_handle *NativeHandle) {
return pi2ur::piextPlatformGetNativeHandle(Platform, NativeHandle);
}
pi_result piextPlatformCreateWithNativeHandle(pi_native_handle NativeHandle,
pi_platform *Platform) {
return pi2ur::piextPlatformCreateWithNativeHandle(NativeHandle, Platform);
}
pi_result piPluginGetLastError(char **message) {
return pi2ur::piPluginGetLastError(message);
}
// Returns plugin specific backend option.
// Return '-ze-opt-disable' for frontend_option = -O0.
// Return '-ze-opt-level=1' for frontend_option = -O1 or -O2.
// Return '-ze-opt-level=2' for frontend_option = -O3.
// Return '-igc_opts 'PartitionUnit=1,SubroutineThreshold=50000'' for
// frontend_option = -ftarget-compile-fast.
pi_result piPluginGetBackendOption(pi_platform platform,
const char *frontend_option,
const char **backend_option) {
return pi2ur::piPluginGetBackendOption(platform, frontend_option,
backend_option);
}
pi_result piDevicesGet(pi_platform Platform, pi_device_type DeviceType,
pi_uint32 NumEntries, pi_device *Devices,
pi_uint32 *NumDevices) {
return pi2ur::piDevicesGet(Platform, DeviceType, NumEntries, Devices,
NumDevices);
}
pi_result piDeviceRetain(pi_device Device) {
return pi2ur::piDeviceRetain(Device);
}
pi_result piDeviceRelease(pi_device Device) {
return pi2ur::piDeviceRelease(Device);
}
pi_result piDeviceGetInfo(pi_device Device, pi_device_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piDeviceGetInfo(Device, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piDevicePartition(pi_device Device,
const pi_device_partition_property *Properties,
pi_uint32 NumDevices, pi_device *OutDevices,
pi_uint32 *OutNumDevices) {
return pi2ur::piDevicePartition(Device, Properties, NumDevices, OutDevices,
OutNumDevices);
}
pi_result
piextDeviceSelectBinary(pi_device Device, // TODO: does this need to be context?
pi_device_binary *Binaries, pi_uint32 NumBinaries,
pi_uint32 *SelectedBinaryInd) {
return pi2ur::piextDeviceSelectBinary(Device, Binaries, NumBinaries,
SelectedBinaryInd);
}
pi_result piextDeviceGetNativeHandle(pi_device Device,
pi_native_handle *NativeHandle) {
return pi2ur::piextDeviceGetNativeHandle(Device, NativeHandle);
}
pi_result piextDeviceCreateWithNativeHandle(pi_native_handle NativeHandle,
pi_platform Platform,
pi_device *Device) {
return pi2ur::piextDeviceCreateWithNativeHandle(NativeHandle, Platform,
Device);
}
pi_result piContextCreate(const pi_context_properties *Properties,
pi_uint32 NumDevices, const pi_device *Devices,
void (*PFnNotify)(const char *ErrInfo,
const void *PrivateInfo, size_t CB,
void *UserData),
void *UserData, pi_context *RetContext) {
return pi2ur::piContextCreate(Properties, NumDevices, Devices, PFnNotify,
UserData, RetContext);
}
pi_result piContextGetInfo(pi_context Context, pi_context_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piContextGetInfo(Context, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
// FIXME: Dummy implementation to prevent link fail
pi_result piextContextSetExtendedDeleter(pi_context Context,
pi_context_extended_deleter Function,
void *UserData) {
return pi2ur::piextContextSetExtendedDeleter(Context, Function, UserData);
}
pi_result piextContextGetNativeHandle(pi_context Context,
pi_native_handle *NativeHandle) {
return pi2ur::piextContextGetNativeHandle(Context, NativeHandle);
}
pi_result piextContextCreateWithNativeHandle(pi_native_handle NativeHandle,
pi_uint32 NumDevices,
const pi_device *Devices,
bool OwnNativeHandle,
pi_context *RetContext) {
return pi2ur::piextContextCreateWithNativeHandle(
NativeHandle, NumDevices, Devices, OwnNativeHandle, RetContext);
}
pi_result piContextRetain(pi_context Context) {
return pi2ur::piContextRetain(Context);
}
pi_result piContextRelease(pi_context Context) {
return pi2ur::piContextRelease(Context);
}
pi_result piQueueCreate(pi_context Context, pi_device Device,
pi_queue_properties Flags, pi_queue *Queue) {
pi_queue_properties Properties[] = {PI_QUEUE_FLAGS, Flags, 0};
return piextQueueCreate(Context, Device, Properties, Queue);
}
pi_result piextQueueCreate(pi_context Context, pi_device Device,
pi_queue_properties *Properties, pi_queue *Queue) {
return pi2ur::piextQueueCreate(Context, Device, Properties, Queue);
}
pi_result piQueueGetInfo(pi_queue Queue, pi_queue_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piQueueGetInfo(Queue, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piQueueRetain(pi_queue Queue) { return pi2ur::piQueueRetain(Queue); }
pi_result piQueueRelease(pi_queue Queue) {
return pi2ur::piQueueRelease(Queue);
}
pi_result piQueueFinish(pi_queue Queue) { return pi2ur::piQueueFinish(Queue); }
pi_result piQueueFlush(pi_queue Queue) { return pi2ur::piQueueFlush(Queue); }
pi_result piextQueueGetNativeHandle(pi_queue Queue,
pi_native_handle *NativeHandle,
int32_t *NativeHandleDesc) {
return pi2ur::piextQueueGetNativeHandle(Queue, NativeHandle,
NativeHandleDesc);
}
pi_result piextQueueCreateWithNativeHandle(pi_native_handle NativeHandle,
int32_t NativeHandleDesc,
pi_context Context, pi_device Device,
bool OwnNativeHandle,
pi_queue_properties *Properties,
pi_queue *Queue) {
return pi2ur::piextQueueCreateWithNativeHandle(
NativeHandle, NativeHandleDesc, Context, Device, OwnNativeHandle,
Properties, Queue);
}
pi_result piMemBufferCreate(pi_context Context, pi_mem_flags Flags, size_t Size,
void *HostPtr, pi_mem *RetMem,
const pi_mem_properties *properties) {
return pi2ur::piMemBufferCreate(Context, Flags, Size, HostPtr, RetMem,
properties);
}
pi_result piMemGetInfo(pi_mem Mem, pi_mem_info ParamName, size_t ParamValueSize,
void *ParamValue, size_t *ParamValueSizeRet) {
return pi2ur::piMemGetInfo(Mem, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piMemRetain(pi_mem Mem) { return pi2ur::piMemRetain(Mem); }
pi_result piMemRelease(pi_mem Mem) { return pi2ur::piMemRelease(Mem); }
pi_result piMemImageCreate(pi_context Context, pi_mem_flags Flags,
const pi_image_format *ImageFormat,
const pi_image_desc *ImageDesc, void *HostPtr,
pi_mem *RetImage) {
return pi2ur::piMemImageCreate(Context, Flags, ImageFormat, ImageDesc,
HostPtr, RetImage);
}
pi_result piextMemGetNativeHandle(pi_mem Mem, pi_native_handle *NativeHandle) {
return pi2ur::piextMemGetNativeHandle(Mem, NativeHandle);
}
pi_result piextMemCreateWithNativeHandle(pi_native_handle NativeHandle,
pi_context Context,
bool ownNativeHandle, pi_mem *Mem) {
return pi2ur::piextMemCreateWithNativeHandle(NativeHandle, Context,
ownNativeHandle, Mem);
}
pi_result piProgramCreate(pi_context Context, const void *ILBytes,
size_t Length, pi_program *Program) {
return pi2ur::piProgramCreate(Context, ILBytes, Length, Program);
}
pi_result piProgramCreateWithBinary(
pi_context Context, pi_uint32 NumDevices, const pi_device *DeviceList,
const size_t *Lengths, const unsigned char **Binaries,
size_t NumMetadataEntries, const pi_device_binary_property *Metadata,
pi_int32 *BinaryStatus, pi_program *Program) {
return pi2ur::piProgramCreateWithBinary(Context, NumDevices, DeviceList,
Lengths, Binaries, NumMetadataEntries,
Metadata, BinaryStatus, Program);
}
pi_result piextMemImageCreateWithNativeHandle(
pi_native_handle NativeHandle, pi_context Context, bool OwnNativeHandle,
const pi_image_format *ImageFormat, const pi_image_desc *ImageDesc,
pi_mem *Img) {
return pi2ur::piextMemImageCreateWithNativeHandle(
NativeHandle, Context, OwnNativeHandle, ImageFormat, ImageDesc, Img);
}
pi_result piclProgramCreateWithSource(pi_context Context, pi_uint32 Count,
const char **Strings,
const size_t *Lengths,
pi_program *RetProgram) {
return pi2ur::piclProgramCreateWithSource(Context, Count, Strings, Lengths,
RetProgram);
}
pi_result piProgramGetInfo(pi_program Program, pi_program_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piProgramGetInfo(Program, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piProgramLink(pi_context Context, pi_uint32 NumDevices,
const pi_device *DeviceList, const char *Options,
pi_uint32 NumInputPrograms,
const pi_program *InputPrograms,
void (*PFnNotify)(pi_program Program, void *UserData),
void *UserData, pi_program *RetProgram) {
return pi2ur::piProgramLink(Context, NumDevices, DeviceList, Options,
NumInputPrograms, InputPrograms, PFnNotify,
UserData, RetProgram);
}
pi_result piProgramCompile(
pi_program Program, pi_uint32 NumDevices, const pi_device *DeviceList,
const char *Options, pi_uint32 NumInputHeaders,
const pi_program *InputHeaders, const char **HeaderIncludeNames,
void (*PFnNotify)(pi_program Program, void *UserData), void *UserData) {
return pi2ur::piProgramCompile(Program, NumDevices, DeviceList, Options,
NumInputHeaders, InputHeaders,
HeaderIncludeNames, PFnNotify, UserData);
}
pi_result piProgramBuild(pi_program Program, pi_uint32 NumDevices,
const pi_device *DeviceList, const char *Options,
void (*PFnNotify)(pi_program Program, void *UserData),
void *UserData) {
return pi2ur::piProgramBuild(Program, NumDevices, DeviceList, Options,
PFnNotify, UserData);
}
pi_result piProgramGetBuildInfo(pi_program Program, pi_device Device,
pi_program_build_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piProgramGetBuildInfo(Program, Device, ParamName,
ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piProgramRetain(pi_program Program) {
return pi2ur::piProgramRetain(Program);
}
pi_result piProgramRelease(pi_program Program) {
return pi2ur::piProgramRelease(Program);
}
pi_result piextProgramGetNativeHandle(pi_program Program,
pi_native_handle *NativeHandle) {
return pi2ur::piextProgramGetNativeHandle(Program, NativeHandle);
}
pi_result piextProgramCreateWithNativeHandle(pi_native_handle NativeHandle,
pi_context Context,
bool OwnNativeHandle,
pi_program *Program) {
return pi2ur::piextProgramCreateWithNativeHandle(NativeHandle, Context,
OwnNativeHandle, Program);
}
pi_result piKernelCreate(pi_program Program, const char *KernelName,
pi_kernel *RetKernel) {
return pi2ur::piKernelCreate(Program, KernelName, RetKernel);
}
pi_result piKernelSetArg(pi_kernel Kernel, pi_uint32 ArgIndex, size_t ArgSize,
const void *ArgValue) {
return pi2ur::piKernelSetArg(Kernel, ArgIndex, ArgSize, ArgValue);
}
// Special version of piKernelSetArg to accept pi_mem.
pi_result piextKernelSetArgMemObj(pi_kernel Kernel, pi_uint32 ArgIndex,
const pi_mem_obj_property *ArgProperties,
const pi_mem *ArgValue) {
return pi2ur::piextKernelSetArgMemObj(Kernel, ArgIndex, ArgProperties,
ArgValue);
}
// Special version of piKernelSetArg to accept pi_sampler.
pi_result piextKernelSetArgSampler(pi_kernel Kernel, pi_uint32 ArgIndex,
const pi_sampler *ArgValue) {
return pi2ur::piextKernelSetArgSampler(Kernel, ArgIndex, ArgValue);
}
pi_result piKernelGetInfo(pi_kernel Kernel, pi_kernel_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piKernelGetInfo(Kernel, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piKernelGetGroupInfo(pi_kernel Kernel, pi_device Device,
pi_kernel_group_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piKernelGetGroupInfo(Kernel, Device, ParamName, ParamValueSize,
ParamValue, ParamValueSizeRet);
}
pi_result piKernelGetSubGroupInfo(pi_kernel Kernel, pi_device Device,
pi_kernel_sub_group_info ParamName,
size_t InputValueSize, const void *InputValue,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piKernelGetSubGroupInfo(
Kernel, Device, ParamName, InputValueSize, InputValue, ParamValueSize,
ParamValue, ParamValueSizeRet);
}
pi_result piKernelRetain(pi_kernel Kernel) {
return pi2ur::piKernelRetain(Kernel);
}
pi_result piKernelRelease(pi_kernel Kernel) {
return pi2ur::piKernelRelease(Kernel);
}
pi_result
piEnqueueKernelLaunch(pi_queue Queue, pi_kernel Kernel, pi_uint32 WorkDim,
const size_t *GlobalWorkOffset,
const size_t *GlobalWorkSize, const size_t *LocalWorkSize,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList, pi_event *OutEvent) {
return pi2ur::piEnqueueKernelLaunch(
Queue, Kernel, WorkDim, GlobalWorkOffset, GlobalWorkSize, LocalWorkSize,
NumEventsInWaitList, EventWaitList, OutEvent);
}
pi_result piextKernelCreateWithNativeHandle(pi_native_handle NativeHandle,
pi_context Context,
pi_program Program,
bool OwnNativeHandle,
pi_kernel *Kernel) {
return pi2ur::piextKernelCreateWithNativeHandle(
NativeHandle, Context, Program, OwnNativeHandle, Kernel);
}
pi_result piextKernelGetNativeHandle(pi_kernel Kernel,
pi_native_handle *NativeHandle) {
return pi2ur::piextKernelGetNativeHandle(Kernel, NativeHandle);
}
//
// Events
//
// External PI API entry
pi_result piEventCreate(pi_context Context, pi_event *RetEvent) {
return pi2ur::piEventCreate(Context, RetEvent);
}
pi_result piEventGetInfo(pi_event Event, pi_event_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piEventGetInfo(Event, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piEventGetProfilingInfo(pi_event Event, pi_profiling_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piEventGetProfilingInfo(Event, ParamName, ParamValueSize,
ParamValue, ParamValueSizeRet);
}
pi_result piEventsWait(pi_uint32 NumEvents, const pi_event *EventList) {
return pi2ur::piEventsWait(NumEvents, EventList);
}
pi_result piEventSetCallback(pi_event Event, pi_int32 CommandExecCallbackType,
void (*PFnNotify)(pi_event Event,
pi_int32 EventCommandStatus,
void *UserData),
void *UserData) {
return pi2ur::piEventSetCallback(Event, CommandExecCallbackType, PFnNotify,
UserData);
}
pi_result piEventSetStatus(pi_event Event, pi_int32 ExecutionStatus) {
return pi2ur::piEventSetStatus(Event, ExecutionStatus);
}
pi_result piEventRetain(pi_event Event) { return pi2ur::piEventRetain(Event); }
pi_result piEventRelease(pi_event Event) {
return pi2ur::piEventRelease(Event);
}
pi_result piextEventGetNativeHandle(pi_event Event,
pi_native_handle *NativeHandle) {
return pi2ur::piextEventGetNativeHandle(Event, NativeHandle);
}
pi_result piextEventCreateWithNativeHandle(pi_native_handle NativeHandle,
pi_context Context,
bool OwnNativeHandle,
pi_event *Event) {
return pi2ur::piextEventCreateWithNativeHandle(NativeHandle, Context,
OwnNativeHandle, Event);
}
//
// Sampler
//
pi_result piSamplerCreate(pi_context Context,
const pi_sampler_properties *SamplerProperties,
pi_sampler *RetSampler) {
return pi2ur::piSamplerCreate(Context, SamplerProperties, RetSampler);
}
pi_result piSamplerGetInfo(pi_sampler Sampler, pi_sampler_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piSamplerGetInfo(Sampler, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piSamplerRetain(pi_sampler Sampler) {
return pi2ur::piSamplerRetain(Sampler);
}
pi_result piSamplerRelease(pi_sampler Sampler) {
return pi2ur::piSamplerRelease(Sampler);
}
//
// Queue Commands
//
pi_result piEnqueueEventsWait(pi_queue Queue, pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *OutEvent) {
return pi2ur::piEnqueueEventsWait(Queue, NumEventsInWaitList, EventWaitList,
OutEvent);
}
pi_result piEnqueueEventsWaitWithBarrier(pi_queue Queue,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *OutEvent) {
return pi2ur::piEnqueueEventsWaitWithBarrier(Queue, NumEventsInWaitList,
EventWaitList, OutEvent);
}
pi_result piEnqueueMemBufferRead(pi_queue Queue, pi_mem Src,
pi_bool BlockingRead, size_t Offset,
size_t Size, void *Dst,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemBufferRead(Queue, Src, BlockingRead, Offset, Size,
Dst, NumEventsInWaitList, EventWaitList,
Event);
}
pi_result piEnqueueMemBufferReadRect(
pi_queue Queue, pi_mem Buffer, pi_bool BlockingRead,
pi_buff_rect_offset BufferOffset, pi_buff_rect_offset HostOffset,
pi_buff_rect_region Region, size_t BufferRowPitch, size_t BufferSlicePitch,
size_t HostRowPitch, size_t HostSlicePitch, void *Ptr,
pi_uint32 NumEventsInWaitList, const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemBufferReadRect(
Queue, Buffer, BlockingRead, BufferOffset, HostOffset, Region,
BufferRowPitch, BufferSlicePitch, HostRowPitch, HostSlicePitch, Ptr,
NumEventsInWaitList, EventWaitList, Event);
}
pi_result piEnqueueMemBufferWrite(pi_queue Queue, pi_mem Buffer,
pi_bool BlockingWrite, size_t Offset,
size_t Size, const void *Ptr,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemBufferWrite(Queue, Buffer, BlockingWrite, Offset,
Size, Ptr, NumEventsInWaitList,
EventWaitList, Event);
}
pi_result piEnqueueMemBufferWriteRect(
pi_queue Queue, pi_mem Buffer, pi_bool BlockingWrite,
pi_buff_rect_offset BufferOffset, pi_buff_rect_offset HostOffset,
pi_buff_rect_region Region, size_t BufferRowPitch, size_t BufferSlicePitch,
size_t HostRowPitch, size_t HostSlicePitch, const void *Ptr,
pi_uint32 NumEventsInWaitList, const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemBufferWriteRect(
Queue, Buffer, BlockingWrite, BufferOffset, HostOffset, Region,
BufferRowPitch, BufferSlicePitch, HostRowPitch, HostSlicePitch, Ptr,
NumEventsInWaitList, EventWaitList, Event);
}
pi_result piEnqueueMemBufferCopy(pi_queue Queue, pi_mem SrcMem, pi_mem DstMem,
size_t SrcOffset, size_t DstOffset,
size_t Size, pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemBufferCopy(Queue, SrcMem, DstMem, SrcOffset,
DstOffset, Size, NumEventsInWaitList,
EventWaitList, Event);
}
pi_result piEnqueueMemBufferCopyRect(
pi_queue Queue, pi_mem SrcMem, pi_mem DstMem, pi_buff_rect_offset SrcOrigin,
pi_buff_rect_offset DstOrigin, pi_buff_rect_region Region,
size_t SrcRowPitch, size_t SrcSlicePitch, size_t DstRowPitch,
size_t DstSlicePitch, pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList, pi_event *Event) {
return pi2ur::piEnqueueMemBufferCopyRect(
Queue, SrcMem, DstMem, SrcOrigin, DstOrigin, Region, SrcRowPitch,
SrcSlicePitch, DstRowPitch, DstSlicePitch, NumEventsInWaitList,
EventWaitList, Event);
}
pi_result piEnqueueMemBufferFill(pi_queue Queue, pi_mem Buffer,
const void *Pattern, size_t PatternSize,
size_t Offset, size_t Size,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemBufferFill(Queue, Buffer, Pattern, PatternSize,
Offset, Size, NumEventsInWaitList,
EventWaitList, Event);
}
pi_result piEnqueueMemBufferMap(pi_queue Queue, pi_mem Mem, pi_bool BlockingMap,
pi_map_flags MapFlags, size_t Offset,
size_t Size, pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *OutEvent, void **RetMap) {
return pi2ur::piEnqueueMemBufferMap(Queue, Mem, BlockingMap, MapFlags, Offset,
Size, NumEventsInWaitList, EventWaitList,
OutEvent, RetMap);
}
pi_result piEnqueueMemUnmap(pi_queue Queue, pi_mem Mem, void *MappedPtr,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList, pi_event *OutEvent) {
return pi2ur::piEnqueueMemUnmap(Queue, Mem, MappedPtr, NumEventsInWaitList,
EventWaitList, OutEvent);
}
pi_result piMemImageGetInfo(pi_mem Image, pi_image_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piMemImageGetInfo(Image, ParamName, ParamValueSize, ParamValue,
ParamValueSizeRet);
}
pi_result piEnqueueMemImageRead(pi_queue Queue, pi_mem Image,
pi_bool BlockingRead, pi_image_offset Origin,
pi_image_region Region, size_t RowPitch,
size_t SlicePitch, void *Ptr,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemImageRead(
Queue, Image, BlockingRead, Origin, Region, RowPitch, SlicePitch, Ptr,
NumEventsInWaitList, EventWaitList, Event);
}
pi_result piEnqueueMemImageWrite(pi_queue Queue, pi_mem Image,
pi_bool BlockingWrite, pi_image_offset Origin,
pi_image_region Region, size_t InputRowPitch,
size_t InputSlicePitch, const void *Ptr,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemImageWrite(
Queue, Image, BlockingWrite, Origin, Region, InputRowPitch,
InputSlicePitch, Ptr, NumEventsInWaitList, EventWaitList, Event);
}
pi_result
piEnqueueMemImageCopy(pi_queue Queue, pi_mem SrcImage, pi_mem DstImage,
pi_image_offset SrcOrigin, pi_image_offset DstOrigin,
pi_image_region Region, pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList, pi_event *Event) {
return pi2ur::piEnqueueMemImageCopy(Queue, SrcImage, DstImage, SrcOrigin,
DstOrigin, Region, NumEventsInWaitList,
EventWaitList, Event);
}
pi_result piEnqueueMemImageFill(pi_queue Queue, pi_mem Image,
const void *FillColor, const size_t *Origin,
const size_t *Region,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueMemImageFill(Queue, Image, FillColor, Origin, Region,
NumEventsInWaitList, EventWaitList,
Event);
}
pi_result piMemBufferPartition(pi_mem Buffer, pi_mem_flags Flags,
pi_buffer_create_type BufferCreateType,
void *BufferCreateInfo, pi_mem *RetMem) {
return pi2ur::piMemBufferPartition(Buffer, Flags, BufferCreateType,
BufferCreateInfo, RetMem);
}
pi_result piEnqueueNativeKernel(pi_queue Queue, void (*UserFunc)(void *),
void *Args, size_t CbArgs,
pi_uint32 NumMemObjects, const pi_mem *MemList,
const void **ArgsMemLoc,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *Event) {
return pi2ur::piEnqueueNativeKernel(
Queue, UserFunc, Args, CbArgs, NumMemObjects, MemList, ArgsMemLoc,
NumEventsInWaitList, EventWaitList, Event);
}
// TODO: Check if the function_pointer_ret type can be converted to void**.
pi_result piextGetDeviceFunctionPointer(pi_device Device, pi_program Program,
const char *FunctionName,
pi_uint64 *FunctionPointerRet) {
return pi2ur::piextGetDeviceFunctionPointer(Device, Program, FunctionName,
FunctionPointerRet);
}
pi_result piextUSMDeviceAlloc(void **ResultPtr, pi_context Context,
pi_device Device,
pi_usm_mem_properties *Properties, size_t Size,
pi_uint32 Alignment) {
return pi2ur::piextUSMDeviceAlloc(ResultPtr, Context, Device, Properties,
Size, Alignment);
}
pi_result piextUSMSharedAlloc(void **ResultPtr, pi_context Context,
pi_device Device,
pi_usm_mem_properties *Properties, size_t Size,
pi_uint32 Alignment) {
return pi2ur::piextUSMSharedAlloc(ResultPtr, Context, Device, Properties,
Size, Alignment);
}
pi_result piextUSMHostAlloc(void **ResultPtr, pi_context Context,
pi_usm_mem_properties *Properties, size_t Size,
pi_uint32 Alignment) {
return pi2ur::piextUSMHostAlloc(ResultPtr, Context, Properties, Size,
Alignment);
}
pi_result piextUSMFree(pi_context Context, void *Ptr) {
return pi2ur::piextUSMFree(Context, Ptr);
}
pi_result piextKernelSetArgPointer(pi_kernel Kernel, pi_uint32 ArgIndex,
size_t ArgSize, const void *ArgValue) {
return pi2ur::piextKernelSetArgPointer(Kernel, ArgIndex, ArgSize, ArgValue);
}
/// USM Memset API
///
/// @param Queue is the queue to submit to
/// @param Ptr is the ptr to memset
/// @param Value is value to set. It is interpreted as an 8-bit value and the
/// upper
/// 24 bits are ignored
/// @param Count is the size in bytes to memset
/// @param NumEventsInWaitlist is the number of events to wait on
/// @param EventsWaitlist is an array of events to wait on
/// @param Event is the event that represents this operation
pi_result piextUSMEnqueueMemset(pi_queue Queue, void *Ptr, pi_int32 Value,
size_t Count, pi_uint32 NumEventsInWaitlist,
const pi_event *EventsWaitlist,
pi_event *Event) {
return pi2ur::piextUSMEnqueueMemset(
Queue, Ptr, Value, Count, NumEventsInWaitlist, EventsWaitlist, Event);
}
pi_result piextUSMEnqueueMemcpy(pi_queue Queue, pi_bool Blocking, void *DstPtr,
const void *SrcPtr, size_t Size,
pi_uint32 NumEventsInWaitlist,
const pi_event *EventsWaitlist,
pi_event *Event) {
return pi2ur::piextUSMEnqueueMemcpy(Queue, Blocking, DstPtr, SrcPtr, Size,
NumEventsInWaitlist, EventsWaitlist,
Event);
}
/// Hint to migrate memory to the device
///
/// @param Queue is the queue to submit to
/// @param Ptr points to the memory to migrate
/// @param Size is the number of bytes to migrate
/// @param Flags is a bitfield used to specify memory migration options
/// @param NumEventsInWaitlist is the number of events to wait on
/// @param EventsWaitlist is an array of events to wait on
/// @param Event is the event that represents this operation
pi_result piextUSMEnqueuePrefetch(pi_queue Queue, const void *Ptr, size_t Size,
pi_usm_migration_flags Flags,
pi_uint32 NumEventsInWaitList,
const pi_event *EventWaitList,
pi_event *OutEvent) {
return pi2ur::piextUSMEnqueuePrefetch(
Queue, Ptr, Size, Flags, NumEventsInWaitList, EventWaitList, OutEvent);
}
/// USM memadvise API to govern behavior of automatic migration mechanisms
///
/// @param Queue is the queue to submit to
/// @param Ptr is the data to be advised
/// @param Length is the size in bytes of the meory to advise
/// @param Advice is device specific advice
/// @param Event is the event that represents this operation
///
pi_result piextUSMEnqueueMemAdvise(pi_queue Queue, const void *Ptr,
size_t Length, pi_mem_advice Advice,
pi_event *OutEvent) {
return pi2ur::piextUSMEnqueueMemAdvise(Queue, Ptr, Length, Advice, OutEvent);
}
/// USM 2D Fill API
///
/// \param queue is the queue to submit to
/// \param ptr is the ptr to fill
/// \param pitch is the total width of the destination memory including padding
/// \param pattern is a pointer with the bytes of the pattern to set
/// \param pattern_size is the size in bytes of the pattern
/// \param width is width in bytes of each row to fill
/// \param height is height the columns to fill
/// \param num_events_in_waitlist is the number of events to wait on
/// \param events_waitlist is an array of events to wait on
/// \param event is the event that represents this operation
__SYCL_EXPORT pi_result piextUSMEnqueueFill2D(pi_queue Queue, void *Ptr,
size_t Pitch, size_t PatternSize,
const void *Pattern, size_t Width,
size_t Height,
pi_uint32 NumEventsWaitList,
const pi_event *EventsWaitList,
pi_event *Event) {
return pi2ur::piextUSMEnqueueFill2D(Queue, Ptr, Pitch, PatternSize, Pattern,
Width, Height, NumEventsWaitList,
EventsWaitList, Event);
}
/// USM 2D Memset API
///
/// \param queue is the queue to submit to
/// \param ptr is the ptr to fill
/// \param pitch is the total width of the destination memory including padding
/// \param pattern is a pointer with the bytes of the pattern to set
/// \param pattern_size is the size in bytes of the pattern
/// \param width is width in bytes of each row to fill
/// \param height is height the columns to fill
/// \param num_events_in_waitlist is the number of events to wait on
/// \param events_waitlist is an array of events to wait on
/// \param event is the event that represents this operation
__SYCL_EXPORT pi_result piextUSMEnqueueMemset2D(pi_queue Queue, void *Ptr,
size_t Pitch, int Value,
size_t Width, size_t Height,
pi_uint32 NumEventsWaitList,
const pi_event *EventsWaitlist,
pi_event *Event) {
return pi2ur::piextUSMEnqueueMemset2D(Queue, Ptr, Pitch, Value, Width, Height,
NumEventsWaitList, EventsWaitlist,
Event);
}
/// USM 2D Memcpy API
///
/// \param queue is the queue to submit to
/// \param blocking is whether this operation should block the host
/// \param dst_ptr is the location the data will be copied
/// \param dst_pitch is the total width of the destination memory including
/// padding
/// \param src_ptr is the data to be copied
/// \param dst_pitch is the total width of the source memory including padding
/// \param width is width in bytes of each row to be copied
/// \param height is height the columns to be copied
/// \param num_events_in_waitlist is the number of events to wait on
/// \param events_waitlist is an array of events to wait on
/// \param event is the event that represents this operation
__SYCL_EXPORT pi_result piextUSMEnqueueMemcpy2D(
pi_queue Queue, pi_bool Blocking, void *DstPtr, size_t DstPitch,
const void *SrcPtr, size_t SrcPitch, size_t Width, size_t Height,
pi_uint32 NumEventsInWaitlist, const pi_event *EventWaitlist,
pi_event *Event) {
return pi2ur::piextUSMEnqueueMemcpy2D(
Queue, Blocking, DstPtr, DstPitch, SrcPtr, SrcPitch, Width, Height,
NumEventsInWaitlist, EventWaitlist, Event);
}
/// API to query information about USM allocated pointers.
/// Valid Queries:
/// PI_MEM_ALLOC_TYPE returns host/device/shared pi_usm_type value
/// PI_MEM_ALLOC_BASE_PTR returns the base ptr of an allocation if
/// the queried pointer fell inside an allocation.
/// Result must fit in void *
/// PI_MEM_ALLOC_SIZE returns how big the queried pointer's
/// allocation is in bytes. Result is a size_t.
/// PI_MEM_ALLOC_DEVICE returns the pi_device this was allocated against
///
/// @param Context is the pi_context
/// @param Ptr is the pointer to query
/// @param ParamName is the type of query to perform
/// @param ParamValueSize is the size of the result in bytes
/// @param ParamValue is the result
/// @param ParamValueRet is how many bytes were written
pi_result piextUSMGetMemAllocInfo(pi_context Context, const void *Ptr,
pi_mem_alloc_info ParamName,
size_t ParamValueSize, void *ParamValue,
size_t *ParamValueSizeRet) {
return pi2ur::piextUSMGetMemAllocInfo(Context, Ptr, ParamName, ParamValueSize,
ParamValue, ParamValueSizeRet);
}
/// API for writing data from host to a device global variable.
///
/// \param Queue is the queue
/// \param Program is the program containing the device global variable
/// \param Name is the unique identifier for the device global variable
/// \param BlockingWrite is true if the write should block
/// \param Count is the number of bytes to copy
/// \param Offset is the byte offset into the device global variable to start
/// copying
/// \param Src is a pointer to where the data must be copied from
/// \param NumEventsInWaitList is a number of events in the wait list
/// \param EventWaitList is the wait list
/// \param Event is the resulting event
pi_result piextEnqueueDeviceGlobalVariableWrite(
pi_queue Queue, pi_program Program, const char *Name, pi_bool BlockingWrite,
size_t Count, size_t Offset, const void *Src, pi_uint32 NumEventsInWaitList,
const pi_event *EventsWaitList, pi_event *Event) {
return pi2ur::piextEnqueueDeviceGlobalVariableWrite(
Queue, Program, Name, BlockingWrite, Count, Offset, Src,
NumEventsInWaitList, EventsWaitList, Event);
}
/// API reading data from a device global variable to host.
///
/// \param Queue is the queue
/// \param Program is the program containing the device global variable
/// \param Name is the unique identifier for the device global variable
/// \param BlockingRead is true if the read should block
/// \param Count is the number of bytes to copy
/// \param Offset is the byte offset into the device global variable to start
/// copying
/// \param Dst is a pointer to where the data must be copied to
/// \param NumEventsInWaitList is a number of events in the wait list
/// \param EventWaitList is the wait list
/// \param Event is the resulting event
pi_result piextEnqueueDeviceGlobalVariableRead(
pi_queue Queue, pi_program Program, const char *Name, pi_bool BlockingRead,
size_t Count, size_t Offset, void *Dst, pi_uint32 NumEventsInWaitList,
const pi_event *EventsWaitList, pi_event *Event) {
return pi2ur::piextEnqueueDeviceGlobalVariableRead(
Queue, Program, Name, BlockingRead, Count, Offset, Dst,
NumEventsInWaitList, EventsWaitList, Event);
return PI_SUCCESS;
}
/// API for Read from host pipe.
///
/// \param Queue is the queue
/// \param Program is the program containing the device variable
/// \param PipeSymbol is the unique identifier for the device variable
/// \param Blocking is true if the write should block
/// \param Ptr is a pointer to where the data will be copied to
/// \param Size is size of the data that is read/written from/to pipe
/// \param NumEventsInWaitList is a number of events in the wait list
/// \param EventWaitList is the wait list
/// \param Event is the resulting event