summaryrefslogtreecommitdiff
path: root/llama.cpp/ggml/src/ggml-opencl/kernels/im2col_f32.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/im2col_f32.cl
downloadllmnpc-b333b06772c89d96aacb5490d6a219fba7c09cc6.tar.gz
Engage!
Diffstat (limited to 'llama.cpp/ggml/src/ggml-opencl/kernels/im2col_f32.cl')
-rw-r--r--llama.cpp/ggml/src/ggml-opencl/kernels/im2col_f32.cl57
1 files changed, 57 insertions, 0 deletions
diff --git a/llama.cpp/ggml/src/ggml-opencl/kernels/im2col_f32.cl b/llama.cpp/ggml/src/ggml-opencl/kernels/im2col_f32.cl
new file mode 100644
index 0000000..1ecdb23
--- /dev/null
+++ b/llama.cpp/ggml/src/ggml-opencl/kernels/im2col_f32.cl
@@ -0,0 +1,57 @@
+#pragma OPENCL EXTENSION cl_khr_fp16 : enable
+
+kernel void kernel_im2col_f32(
+ global float * src1,
+ ulong offset1,
+ global float * dst,
+ ulong offsetd,
+ ulong batch_offset,
+ ulong delta_offset,
+ long IW,
+ long IH,
+ long IC,
+ long OW,
+ long OH,
+ long KW,
+ long KH,
+ long pelements,
+ long CHW,
+ int s0,
+ int s1,
+ int p0,
+ int p1,
+ int d0,
+ int d1
+) {
+ long i = get_global_id(0);
+ if (i >= pelements) {
+ return;
+ }
+
+ src1 = (global float*)((global char*)src1 + offset1);
+ dst = (global float*)((global char*)dst + offsetd);
+
+ long ksize = OW * KH;
+ long kx = i / ksize;
+ long kd = kx * ksize;
+ long ky = (i - kd) / OW;
+ long ix = i % OW;
+
+ long oh = get_group_id(1);
+ long batch = get_group_id(2) / IC;
+ long ic = get_group_id(2) % IC;
+
+ long iiw = ix * s0 + kx * d0 - p0;
+ long iih = oh * s1 + ky * d1 - p1;
+
+ long offset_dst =
+ ((batch * OH + oh) * OW + ix) * CHW +
+ (ic * (KW * KH) + ky * KW + kx);
+
+ if (iih < 0 || iih >= IH || iiw < 0 || iiw >= IW) {
+ dst[offset_dst] = 0.0f;
+ } else {
+ long offset_src = ic * delta_offset + batch * batch_offset;
+ dst[offset_dst] = src1[offset_src + iih * IW + iiw];
+ }
+}