summaryrefslogtreecommitdiff
path: root/llama.cpp/ggml/src/ggml-opencl/kernels/add_id.cl
diff options
context:
space:
mode:
authorMitja Felicijan <mitja.felicijan@gmail.com>2026-02-12 20:57:17 +0100
committerMitja Felicijan <mitja.felicijan@gmail.com>2026-02-12 20:57:17 +0100
commitb333b06772c89d96aacb5490d6a219fba7c09cc6 (patch)
tree211df60083a5946baa2ed61d33d8121b7e251b06 /llama.cpp/ggml/src/ggml-opencl/kernels/add_id.cl
downloadllmnpc-b333b06772c89d96aacb5490d6a219fba7c09cc6.tar.gz
Engage!
Diffstat (limited to 'llama.cpp/ggml/src/ggml-opencl/kernels/add_id.cl')
-rw-r--r--llama.cpp/ggml/src/ggml-opencl/kernels/add_id.cl42
1 files changed, 42 insertions, 0 deletions
diff --git a/llama.cpp/ggml/src/ggml-opencl/kernels/add_id.cl b/llama.cpp/ggml/src/ggml-opencl/kernels/add_id.cl
new file mode 100644
index 0000000..e9c6d55
--- /dev/null
+++ b/llama.cpp/ggml/src/ggml-opencl/kernels/add_id.cl
@@ -0,0 +1,42 @@
+#pragma OPENCL EXTENSION cl_khr_fp16 : enable
+
+//------------------------------------------------------------------------------
+// add_id
+//------------------------------------------------------------------------------
+kernel void kernel_add_id(
+ global char * src0,
+ ulong offset0,
+ global char * src1,
+ ulong offset1,
+ global char * src2,
+ ulong offset2,
+ global char * dst,
+ ulong offsetd,
+ ulong nb01,
+ ulong nb02,
+ ulong nb11,
+ ulong nb21,
+ int ne0,
+ int ne1
+) {
+ src0 = (global char*)((global char*)src0 + offset0);
+ src1 = (global char*)((global char*)src1 + offset1);
+ src2 = (global char*)((global char*)src2 + offset2);
+ dst = (global char*)((global char*)dst + offsetd);
+
+ int i1 = get_group_id(0);
+ int i2 = get_group_id(1);
+
+ const int i11 = *((global const int *) (src2 + i1*sizeof(int) + i2*nb21));
+
+ const size_t nb1 = ne0 * sizeof(float);
+ const size_t nb2 = ne1 * nb1;
+
+ global float * dst_row = (global float *)((global char *)dst + i1*nb1 + i2*nb2);
+ global float * src0_row = (global float *)((global char *)src0 + i1*nb01 + i2*nb02);
+ global float * src1_row = (global float *)((global char *)src1 + i11*nb11);
+
+ for (int i0 = get_local_id(0); i0 < ne0; i0 += get_local_size(0)) {
+ dst_row[i0] = src0_row[i0] + src1_row[i0];
+ }
+}