| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | static void conv3x3s2_pack4_neon(const Mat& bottom_blob, Mat& top_blob, const Mat& kernel, const Mat& _bias, const Option& opt) |
| | { |
| | int w = bottom_blob.w; |
| | int inch = bottom_blob.c; |
| | int outw = top_blob.w; |
| | int outh = top_blob.h; |
| | int outch = top_blob.c; |
| |
|
| | const int tailstep = (w - 2 * outw + w) * 4; |
| |
|
| | const float* bias = _bias; |
| |
|
| | #pragma omp parallel for num_threads(opt.num_threads) |
| | for (int p = 0; p < outch; p++) |
| | { |
| | Mat out0 = top_blob.channel(p); |
| |
|
| | float32x4_t _bias0 = bias ? vld1q_f32((const float*)bias + p * 4) : vdupq_n_f32(0.f); |
| | out0.fill(_bias0); |
| |
|
| | for (int q = 0; q < inch; q++) |
| | { |
| | float* outptr0 = out0.row(0); |
| |
|
| | const Mat img0 = bottom_blob.channel(q); |
| |
|
| | const float* r0 = img0.row(0); |
| | const float* r1 = img0.row(1); |
| | const float* r2 = img0.row(2); |
| |
|
| | const float* kptr = (const float*)kernel.channel(p).row(q); |
| |
|
| | int i = 0; |
| | for (; i < outh; i++) |
| | { |
| | int j = 0; |
| | for (; j + 3 < outw; j += 4) |
| | { |
| | #if __aarch64__ |
| | asm volatile( |
| | "prfm pldl1keep, [%0, #512] \n" |
| | "ld1 {v20.4s, v21.4s, v22.4s, v23.4s}, [%0] \n" |
| | |
| | "prfm pldl1keep, [%1, #512] \n" |
| | "ld1 {v0.4s, v1.4s, v2.4s, v3.4s}, [%1], #64 \n" |
| | |
| | "prfm pldl1keep, [%1, #512] \n" |
| | "ld1 {v4.4s, v5.4s, v6.4s, v7.4s}, [%1], #64 \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v20.4s, v16.4s, v0.s[0] \n" |
| | "fmla v21.4s, v16.4s, v2.s[0] \n" |
| | "fmla v22.4s, v16.4s, v4.s[0] \n" |
| | "fmla v23.4s, v16.4s, v6.s[0] \n" |
| | "fmla v20.4s, v17.4s, v0.s[1] \n" |
| | "fmla v21.4s, v17.4s, v2.s[1] \n" |
| | "fmla v22.4s, v17.4s, v4.s[1] \n" |
| | "fmla v23.4s, v17.4s, v6.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v20.4s, v18.4s, v0.s[2] \n" |
| | "fmla v21.4s, v18.4s, v2.s[2] \n" |
| | "fmla v22.4s, v18.4s, v4.s[2] \n" |
| | "fmla v23.4s, v18.4s, v6.s[2] \n" |
| | "fmla v20.4s, v19.4s, v0.s[3] \n" |
| | "fmla v21.4s, v19.4s, v2.s[3] \n" |
| | "fmla v22.4s, v19.4s, v4.s[3] \n" |
| | "fmla v23.4s, v19.4s, v6.s[3] \n" |
| | |
| | "prfm pldl1keep, [%1, #128] \n" |
| | "ld1 {v28.4s}, [%1] \n" |
| | |
| | "fmla v20.4s, v24.4s, v1.s[0] \n" |
| | "fmla v21.4s, v24.4s, v3.s[0] \n" |
| | "fmla v22.4s, v24.4s, v5.s[0] \n" |
| | "fmla v23.4s, v24.4s, v7.s[0] \n" |
| | "fmla v20.4s, v25.4s, v1.s[1] \n" |
| | "fmla v21.4s, v25.4s, v3.s[1] \n" |
| | "fmla v22.4s, v25.4s, v5.s[1] \n" |
| | "fmla v23.4s, v25.4s, v7.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v20.4s, v26.4s, v1.s[2] \n" |
| | "fmla v21.4s, v26.4s, v3.s[2] \n" |
| | "fmla v22.4s, v26.4s, v5.s[2] \n" |
| | "fmla v23.4s, v26.4s, v7.s[2] \n" |
| | "fmla v20.4s, v27.4s, v1.s[3] \n" |
| | "fmla v21.4s, v27.4s, v3.s[3] \n" |
| | "fmla v22.4s, v27.4s, v5.s[3] \n" |
| | "fmla v23.4s, v27.4s, v7.s[3] \n" |
| | |
| | "prfm pldl1keep, [%2, #512] \n" |
| | "ld1 {v8.4s, v9.4s, v10.4s, v11.4s}, [%2], #64 \n" |
| | |
| | "fmla v20.4s, v16.4s, v2.s[0] \n" |
| | "fmla v21.4s, v16.4s, v4.s[0] \n" |
| | "fmla v22.4s, v16.4s, v6.s[0] \n" |
| | "fmla v23.4s, v16.4s, v28.s[0] \n" |
| | "fmla v20.4s, v17.4s, v2.s[1] \n" |
| | "fmla v21.4s, v17.4s, v4.s[1] \n" |
| | "fmla v22.4s, v17.4s, v6.s[1] \n" |
| | "fmla v23.4s, v17.4s, v28.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v20.4s, v18.4s, v2.s[2] \n" |
| | "fmla v21.4s, v18.4s, v4.s[2] \n" |
| | "fmla v22.4s, v18.4s, v6.s[2] \n" |
| | "fmla v23.4s, v18.4s, v28.s[2] \n" |
| | "fmla v20.4s, v19.4s, v2.s[3] \n" |
| | "fmla v21.4s, v19.4s, v4.s[3] \n" |
| | "fmla v22.4s, v19.4s, v6.s[3] \n" |
| | "fmla v23.4s, v19.4s, v28.s[3] \n" |
| | |
| | "prfm pldl1keep, [%2, #512] \n" |
| | "ld1 {v12.4s, v13.4s, v14.4s, v15.4s}, [%2], #64 \n" |
| | |
| | "fmla v20.4s, v24.4s, v8.s[0] \n" |
| | "fmla v21.4s, v24.4s, v10.s[0] \n" |
| | "fmla v22.4s, v24.4s, v12.s[0] \n" |
| | "fmla v23.4s, v24.4s, v14.s[0] \n" |
| | "fmla v20.4s, v25.4s, v8.s[1] \n" |
| | "fmla v21.4s, v25.4s, v10.s[1] \n" |
| | "fmla v22.4s, v25.4s, v12.s[1] \n" |
| | "fmla v23.4s, v25.4s, v14.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v20.4s, v26.4s, v8.s[2] \n" |
| | "fmla v21.4s, v26.4s, v10.s[2] \n" |
| | "fmla v22.4s, v26.4s, v12.s[2] \n" |
| | "fmla v23.4s, v26.4s, v14.s[2] \n" |
| | "fmla v20.4s, v27.4s, v8.s[3] \n" |
| | "fmla v21.4s, v27.4s, v10.s[3] \n" |
| | "fmla v22.4s, v27.4s, v12.s[3] \n" |
| | "fmla v23.4s, v27.4s, v14.s[3] \n" |
| | |
| | "prfm pldl1keep, [%2, #128] \n" |
| | "ld1 {v28.4s}, [%2] \n" |
| | |
| | "fmla v20.4s, v16.4s, v9.s[0] \n" |
| | "fmla v21.4s, v16.4s, v11.s[0] \n" |
| | "fmla v22.4s, v16.4s, v13.s[0] \n" |
| | "fmla v23.4s, v16.4s, v15.s[0] \n" |
| | "fmla v20.4s, v17.4s, v9.s[1] \n" |
| | "fmla v21.4s, v17.4s, v11.s[1] \n" |
| | "fmla v22.4s, v17.4s, v13.s[1] \n" |
| | "fmla v23.4s, v17.4s, v15.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v20.4s, v18.4s, v9.s[2] \n" |
| | "fmla v21.4s, v18.4s, v11.s[2] \n" |
| | "fmla v22.4s, v18.4s, v13.s[2] \n" |
| | "fmla v23.4s, v18.4s, v15.s[2] \n" |
| | "fmla v20.4s, v19.4s, v9.s[3] \n" |
| | "fmla v21.4s, v19.4s, v11.s[3] \n" |
| | "fmla v22.4s, v19.4s, v13.s[3] \n" |
| | "fmla v23.4s, v19.4s, v15.s[3] \n" |
| | |
| | "prfm pldl1keep, [%3, #512] \n" |
| | "ld1 {v0.4s, v1.4s, v2.4s, v3.4s}, [%3], #64 \n" |
| | |
| | "fmla v20.4s, v24.4s, v10.s[0] \n" |
| | "fmla v21.4s, v24.4s, v12.s[0] \n" |
| | "fmla v22.4s, v24.4s, v14.s[0] \n" |
| | "fmla v23.4s, v24.4s, v28.s[0] \n" |
| | "fmla v20.4s, v25.4s, v10.s[1] \n" |
| | "fmla v21.4s, v25.4s, v12.s[1] \n" |
| | "fmla v22.4s, v25.4s, v14.s[1] \n" |
| | "fmla v23.4s, v25.4s, v28.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v20.4s, v26.4s, v10.s[2] \n" |
| | "fmla v21.4s, v26.4s, v12.s[2] \n" |
| | "fmla v22.4s, v26.4s, v14.s[2] \n" |
| | "fmla v23.4s, v26.4s, v28.s[2] \n" |
| | "fmla v20.4s, v27.4s, v10.s[3] \n" |
| | "fmla v21.4s, v27.4s, v12.s[3] \n" |
| | "fmla v22.4s, v27.4s, v14.s[3] \n" |
| | "fmla v23.4s, v27.4s, v28.s[3] \n" |
| | |
| | "prfm pldl1keep, [%3, #512] \n" |
| | "ld1 {v4.4s, v5.4s, v6.4s, v7.4s}, [%3], #64 \n" |
| | |
| | "fmla v20.4s, v16.4s, v0.s[0] \n" |
| | "fmla v21.4s, v16.4s, v2.s[0] \n" |
| | "fmla v22.4s, v16.4s, v4.s[0] \n" |
| | "fmla v23.4s, v16.4s, v6.s[0] \n" |
| | "fmla v20.4s, v17.4s, v0.s[1] \n" |
| | "fmla v21.4s, v17.4s, v2.s[1] \n" |
| | "fmla v22.4s, v17.4s, v4.s[1] \n" |
| | "fmla v23.4s, v17.4s, v6.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v20.4s, v18.4s, v0.s[2] \n" |
| | "fmla v21.4s, v18.4s, v2.s[2] \n" |
| | "fmla v22.4s, v18.4s, v4.s[2] \n" |
| | "fmla v23.4s, v18.4s, v6.s[2] \n" |
| | "fmla v20.4s, v19.4s, v0.s[3] \n" |
| | "fmla v21.4s, v19.4s, v2.s[3] \n" |
| | "fmla v22.4s, v19.4s, v4.s[3] \n" |
| | "fmla v23.4s, v19.4s, v6.s[3] \n" |
| | |
| | "prfm pldl1keep, [%3, #128] \n" |
| | "ld1 {v28.4s}, [%3] \n" |
| | |
| | "fmla v20.4s, v24.4s, v1.s[0] \n" |
| | "fmla v21.4s, v24.4s, v3.s[0] \n" |
| | "fmla v22.4s, v24.4s, v5.s[0] \n" |
| | "fmla v23.4s, v24.4s, v7.s[0] \n" |
| | "fmla v20.4s, v25.4s, v1.s[1] \n" |
| | "fmla v21.4s, v25.4s, v3.s[1] \n" |
| | "fmla v22.4s, v25.4s, v5.s[1] \n" |
| | "fmla v23.4s, v25.4s, v7.s[1] \n" |
| | |
| | |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4] \n" |
| | |
| | "fmla v20.4s, v26.4s, v1.s[2] \n" |
| | "fmla v21.4s, v26.4s, v3.s[2] \n" |
| | "fmla v22.4s, v26.4s, v5.s[2] \n" |
| | "fmla v23.4s, v26.4s, v7.s[2] \n" |
| | "fmla v20.4s, v27.4s, v1.s[3] \n" |
| | "fmla v21.4s, v27.4s, v3.s[3] \n" |
| | "fmla v22.4s, v27.4s, v5.s[3] \n" |
| | "fmla v23.4s, v27.4s, v7.s[3] \n" |
| | |
| | "fmla v20.4s, v16.4s, v2.s[0] \n" |
| | "fmla v21.4s, v16.4s, v4.s[0] \n" |
| | "fmla v22.4s, v16.4s, v6.s[0] \n" |
| | "fmla v23.4s, v16.4s, v28.s[0] \n" |
| | "fmla v20.4s, v17.4s, v2.s[1] \n" |
| | "fmla v21.4s, v17.4s, v4.s[1] \n" |
| | "fmla v22.4s, v17.4s, v6.s[1] \n" |
| | "fmla v23.4s, v17.4s, v28.s[1] \n" |
| | "fmla v20.4s, v18.4s, v2.s[2] \n" |
| | "fmla v21.4s, v18.4s, v4.s[2] \n" |
| | "fmla v22.4s, v18.4s, v6.s[2] \n" |
| | "fmla v23.4s, v18.4s, v28.s[2] \n" |
| | "fmla v20.4s, v19.4s, v2.s[3] \n" |
| | "fmla v21.4s, v19.4s, v4.s[3] \n" |
| | "fmla v22.4s, v19.4s, v6.s[3] \n" |
| | "fmla v23.4s, v19.4s, v28.s[3] \n" |
| | |
| | "sub %4, %4, #512 \n" |
| | |
| | "st1 {v20.4s, v21.4s, v22.4s, v23.4s}, [%0], #64 \n" |
| | |
| | : "=r"(outptr0), |
| | "=r"(r0), |
| | "=r"(r1), |
| | "=r"(r2), |
| | "=r"(kptr) |
| | : "0"(outptr0), |
| | "1"(r0), |
| | "2"(r1), |
| | "3"(r2), |
| | "4"(kptr) |
| | : "memory", "v0", "v1", "v2", "v3", "v4", "v5", "v6", "v7", "v8", "v9", "v10", "v11", "v12", "v13", "v14", "v15", "v16", "v17", "v18", "v19", "v20", "v21", "v22", "v23", "v24", "v25", "v26", "v27", "v28"); |
| | #else |
| | asm volatile( |
| | "pld [%0, #512] \n" |
| | "vldm %0, {d24-d31} \n" |
| | |
| | "pld [%1, #512] \n" |
| | "vldm %1!, {d0-d7} \n" |
| | |
| | "pld [%1, #512] \n" |
| | "vldm %1!, {d8-d15} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q12, q8, d0[0] \n" |
| | "vmla.f32 q13, q8, d4[0] \n" |
| | "vmla.f32 q14, q8, d8[0] \n" |
| | "vmla.f32 q15, q8, d12[0] \n" |
| | "vmla.f32 q12, q9, d0[1] \n" |
| | "vmla.f32 q13, q9, d4[1] \n" |
| | "vmla.f32 q14, q9, d8[1] \n" |
| | "vmla.f32 q15, q9, d12[1] \n" |
| | "vmla.f32 q12, q10, d1[0] \n" |
| | "vmla.f32 q13, q10, d5[0] \n" |
| | "vmla.f32 q14, q10, d9[0] \n" |
| | "vmla.f32 q15, q10, d13[0] \n" |
| | "vmla.f32 q12, q11, d1[1] \n" |
| | "vmla.f32 q13, q11, d5[1] \n" |
| | "vmla.f32 q14, q11, d9[1] \n" |
| | "vmla.f32 q15, q11, d13[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "pld [%1, #128] \n" |
| | "vld1.f32 {d0-d1}, [%1 :128] \n" |
| | |
| | "vmla.f32 q12, q8, d2[0] \n" |
| | "vmla.f32 q13, q8, d6[0] \n" |
| | "vmla.f32 q14, q8, d10[0] \n" |
| | "vmla.f32 q15, q8, d14[0] \n" |
| | "vmla.f32 q12, q9, d2[1] \n" |
| | "vmla.f32 q13, q9, d6[1] \n" |
| | "vmla.f32 q14, q9, d10[1] \n" |
| | "vmla.f32 q15, q9, d14[1] \n" |
| | "vmla.f32 q12, q10, d3[0] \n" |
| | "vmla.f32 q13, q10, d7[0] \n" |
| | "vmla.f32 q14, q10, d11[0] \n" |
| | "vmla.f32 q15, q10, d15[0] \n" |
| | "vmla.f32 q12, q11, d3[1] \n" |
| | "vmla.f32 q13, q11, d7[1] \n" |
| | "vmla.f32 q14, q11, d11[1] \n" |
| | "vmla.f32 q15, q11, d15[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q12, q8, d4[0] \n" |
| | "vmla.f32 q13, q8, d8[0] \n" |
| | "vmla.f32 q14, q8, d12[0] \n" |
| | "vmla.f32 q15, q8, d0[0] \n" |
| | "vmla.f32 q12, q9, d4[1] \n" |
| | "vmla.f32 q13, q9, d8[1] \n" |
| | "vmla.f32 q14, q9, d12[1] \n" |
| | "vmla.f32 q15, q9, d0[1] \n" |
| | "vmla.f32 q12, q10, d5[0] \n" |
| | "vmla.f32 q13, q10, d9[0] \n" |
| | "vmla.f32 q14, q10, d13[0] \n" |
| | "vmla.f32 q15, q10, d1[0] \n" |
| | "vmla.f32 q12, q11, d5[1] \n" |
| | "vmla.f32 q13, q11, d9[1] \n" |
| | "vmla.f32 q14, q11, d13[1] \n" |
| | "vmla.f32 q15, q11, d1[1] \n" |
| | |
| | "pld [%2, #512] \n" |
| | "vldm %2!, {d8-d15} \n" |
| | |
| | "pld [%2, #512] \n" |
| | "vldm %2!, {d0-d7} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q12, q8, d8[0] \n" |
| | "vmla.f32 q13, q8, d12[0] \n" |
| | "vmla.f32 q14, q8, d0[0] \n" |
| | "vmla.f32 q15, q8, d4[0] \n" |
| | "vmla.f32 q12, q9, d8[1] \n" |
| | "vmla.f32 q13, q9, d12[1] \n" |
| | "vmla.f32 q14, q9, d0[1] \n" |
| | "vmla.f32 q15, q9, d4[1] \n" |
| | "vmla.f32 q12, q10, d9[0] \n" |
| | "vmla.f32 q13, q10, d13[0] \n" |
| | "vmla.f32 q14, q10, d1[0] \n" |
| | "vmla.f32 q15, q10, d5[0] \n" |
| | "vmla.f32 q12, q11, d9[1] \n" |
| | "vmla.f32 q13, q11, d13[1] \n" |
| | "vmla.f32 q14, q11, d1[1] \n" |
| | "vmla.f32 q15, q11, d5[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "pld [%2, #128] \n" |
| | "vld1.f32 {d8-d9}, [%2 :128] \n" |
| | |
| | "vmla.f32 q12, q8, d10[0] \n" |
| | "vmla.f32 q13, q8, d14[0] \n" |
| | "vmla.f32 q14, q8, d2[0] \n" |
| | "vmla.f32 q15, q8, d6[0] \n" |
| | "vmla.f32 q12, q9, d10[1] \n" |
| | "vmla.f32 q13, q9, d14[1] \n" |
| | "vmla.f32 q14, q9, d2[1] \n" |
| | "vmla.f32 q15, q9, d6[1] \n" |
| | "vmla.f32 q12, q10, d11[0] \n" |
| | "vmla.f32 q13, q10, d15[0] \n" |
| | "vmla.f32 q14, q10, d3[0] \n" |
| | "vmla.f32 q15, q10, d7[0] \n" |
| | "vmla.f32 q12, q11, d11[1] \n" |
| | "vmla.f32 q13, q11, d15[1] \n" |
| | "vmla.f32 q14, q11, d3[1] \n" |
| | "vmla.f32 q15, q11, d7[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q12, q8, d12[0] \n" |
| | "vmla.f32 q13, q8, d0[0] \n" |
| | "vmla.f32 q14, q8, d4[0] \n" |
| | "vmla.f32 q15, q8, d8[0] \n" |
| | "vmla.f32 q12, q9, d12[1] \n" |
| | "vmla.f32 q13, q9, d0[1] \n" |
| | "vmla.f32 q14, q9, d4[1] \n" |
| | "vmla.f32 q15, q9, d8[1] \n" |
| | "vmla.f32 q12, q10, d13[0] \n" |
| | "vmla.f32 q13, q10, d1[0] \n" |
| | "vmla.f32 q14, q10, d5[0] \n" |
| | "vmla.f32 q15, q10, d9[0] \n" |
| | "vmla.f32 q12, q11, d13[1] \n" |
| | "vmla.f32 q13, q11, d1[1] \n" |
| | "vmla.f32 q14, q11, d5[1] \n" |
| | "vmla.f32 q15, q11, d9[1] \n" |
| | |
| | "pld [%3, #512] \n" |
| | "vldm %3!, {d0-d7} \n" |
| | |
| | "pld [%3, #512] \n" |
| | "vldm %3!, {d8-d15} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q12, q8, d0[0] \n" |
| | "vmla.f32 q13, q8, d4[0] \n" |
| | "vmla.f32 q14, q8, d8[0] \n" |
| | "vmla.f32 q15, q8, d12[0] \n" |
| | "vmla.f32 q12, q9, d0[1] \n" |
| | "vmla.f32 q13, q9, d4[1] \n" |
| | "vmla.f32 q14, q9, d8[1] \n" |
| | "vmla.f32 q15, q9, d12[1] \n" |
| | "vmla.f32 q12, q10, d1[0] \n" |
| | "vmla.f32 q13, q10, d5[0] \n" |
| | "vmla.f32 q14, q10, d9[0] \n" |
| | "vmla.f32 q15, q10, d13[0] \n" |
| | "vmla.f32 q12, q11, d1[1] \n" |
| | "vmla.f32 q13, q11, d5[1] \n" |
| | "vmla.f32 q14, q11, d9[1] \n" |
| | "vmla.f32 q15, q11, d13[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "pld [%3, #128] \n" |
| | "vld1.f32 {d0-d1}, [%3 :128] \n" |
| | |
| | "vmla.f32 q12, q8, d2[0] \n" |
| | "vmla.f32 q13, q8, d6[0] \n" |
| | "vmla.f32 q14, q8, d10[0] \n" |
| | "vmla.f32 q15, q8, d14[0] \n" |
| | "vmla.f32 q12, q9, d2[1] \n" |
| | "vmla.f32 q13, q9, d6[1] \n" |
| | "vmla.f32 q14, q9, d10[1] \n" |
| | "vmla.f32 q15, q9, d14[1] \n" |
| | "vmla.f32 q12, q10, d3[0] \n" |
| | "vmla.f32 q13, q10, d7[0] \n" |
| | "vmla.f32 q14, q10, d11[0] \n" |
| | "vmla.f32 q15, q10, d15[0] \n" |
| | "vmla.f32 q12, q11, d3[1] \n" |
| | "vmla.f32 q13, q11, d7[1] \n" |
| | "vmla.f32 q14, q11, d11[1] \n" |
| | "vmla.f32 q15, q11, d15[1] \n" |
| | |
| | |
| | "vldm %4, {d16-d23} \n" |
| | |
| | "vmla.f32 q12, q8, d4[0] \n" |
| | "vmla.f32 q13, q8, d8[0] \n" |
| | "vmla.f32 q14, q8, d12[0] \n" |
| | "vmla.f32 q15, q8, d0[0] \n" |
| | "vmla.f32 q12, q9, d4[1] \n" |
| | "vmla.f32 q13, q9, d8[1] \n" |
| | "vmla.f32 q14, q9, d12[1] \n" |
| | "vmla.f32 q15, q9, d0[1] \n" |
| | "vmla.f32 q12, q10, d5[0] \n" |
| | "vmla.f32 q13, q10, d9[0] \n" |
| | "vmla.f32 q14, q10, d13[0] \n" |
| | "vmla.f32 q15, q10, d1[0] \n" |
| | "vmla.f32 q12, q11, d5[1] \n" |
| | "vmla.f32 q13, q11, d9[1] \n" |
| | "vmla.f32 q14, q11, d13[1] \n" |
| | "vmla.f32 q15, q11, d1[1] \n" |
| | |
| | "sub %4, %4, #512 \n" |
| | |
| | "vstm %0!, {d24-d31} \n" |
| | |
| | : "=r"(outptr0), |
| | "=r"(r0), |
| | "=r"(r1), |
| | "=r"(r2), |
| | "=r"(kptr) |
| | : "0"(outptr0), |
| | "1"(r0), |
| | "2"(r1), |
| | "3"(r2), |
| | "4"(kptr) |
| | : "memory", "q0", "q1", "q2", "q3", "q4", "q5", "q6", "q7", "q8", "q9", "q10", "q11", "q12", "q13", "q14", "q15"); |
| | #endif |
| | } |
| | for (; j + 1 < outw; j += 2) |
| | { |
| | #if __aarch64__ |
| | asm volatile( |
| | "prfm pldl1keep, [%0, #256] \n" |
| | "ld1 {v20.4s, v21.4s}, [%0] \n" |
| | |
| | "prfm pldl1keep, [%1, #512] \n" |
| | "ld1 {v0.4s, v1.4s, v2.4s, v3.4s}, [%1], #64 \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmul v22.4s, v16.4s, v0.s[0] \n" |
| | "fmul v23.4s, v16.4s, v2.s[0] \n" |
| | "fmla v20.4s, v17.4s, v0.s[1] \n" |
| | "fmla v21.4s, v17.4s, v2.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v22.4s, v18.4s, v0.s[2] \n" |
| | "fmla v23.4s, v18.4s, v2.s[2] \n" |
| | "fmla v20.4s, v19.4s, v0.s[3] \n" |
| | "fmla v21.4s, v19.4s, v2.s[3] \n" |
| | |
| | "prfm pldl1keep, [%1, #128] \n" |
| | "ld1 {v4.4s}, [%1] \n" |
| | |
| | "fmla v22.4s, v24.4s, v1.s[0] \n" |
| | "fmla v23.4s, v24.4s, v3.s[0] \n" |
| | "fmla v20.4s, v25.4s, v1.s[1] \n" |
| | "fmla v21.4s, v25.4s, v3.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v22.4s, v26.4s, v1.s[2] \n" |
| | "fmla v23.4s, v26.4s, v3.s[2] \n" |
| | "fmla v20.4s, v27.4s, v1.s[3] \n" |
| | "fmla v21.4s, v27.4s, v3.s[3] \n" |
| | |
| | "fmla v22.4s, v16.4s, v2.s[0] \n" |
| | "fmla v23.4s, v16.4s, v4.s[0] \n" |
| | "fmla v20.4s, v17.4s, v2.s[1] \n" |
| | "fmla v21.4s, v17.4s, v4.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v22.4s, v18.4s, v2.s[2] \n" |
| | "fmla v23.4s, v18.4s, v4.s[2] \n" |
| | "fmla v20.4s, v19.4s, v2.s[3] \n" |
| | "fmla v21.4s, v19.4s, v4.s[3] \n" |
| | |
| | "prfm pldl1keep, [%2, #512] \n" |
| | "ld1 {v0.4s, v1.4s, v2.4s, v3.4s}, [%2], #64 \n" |
| | |
| | "fmla v22.4s, v24.4s, v0.s[0] \n" |
| | "fmla v23.4s, v24.4s, v2.s[0] \n" |
| | "fmla v20.4s, v25.4s, v0.s[1] \n" |
| | "fmla v21.4s, v25.4s, v2.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v22.4s, v26.4s, v0.s[2] \n" |
| | "fmla v23.4s, v26.4s, v2.s[2] \n" |
| | "fmla v20.4s, v27.4s, v0.s[3] \n" |
| | "fmla v21.4s, v27.4s, v2.s[3] \n" |
| | |
| | "prfm pldl1keep, [%2, #128] \n" |
| | "ld1 {v4.4s}, [%2] \n" |
| | |
| | "fmla v22.4s, v16.4s, v1.s[0] \n" |
| | "fmla v23.4s, v16.4s, v3.s[0] \n" |
| | "fmla v20.4s, v17.4s, v1.s[1] \n" |
| | "fmla v21.4s, v17.4s, v3.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v22.4s, v18.4s, v1.s[2] \n" |
| | "fmla v23.4s, v18.4s, v3.s[2] \n" |
| | "fmla v20.4s, v19.4s, v1.s[3] \n" |
| | "fmla v21.4s, v19.4s, v3.s[3] \n" |
| | |
| | "fmla v22.4s, v24.4s, v2.s[0] \n" |
| | "fmla v23.4s, v24.4s, v4.s[0] \n" |
| | "fmla v20.4s, v25.4s, v2.s[1] \n" |
| | "fmla v21.4s, v25.4s, v4.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v22.4s, v26.4s, v2.s[2] \n" |
| | "fmla v23.4s, v26.4s, v4.s[2] \n" |
| | "fmla v20.4s, v27.4s, v2.s[3] \n" |
| | "fmla v21.4s, v27.4s, v4.s[3] \n" |
| | |
| | "prfm pldl1keep, [%3, #512] \n" |
| | "ld1 {v0.4s, v1.4s, v2.4s, v3.4s}, [%3], #64 \n" |
| | |
| | "fmla v22.4s, v16.4s, v0.s[0] \n" |
| | "fmla v23.4s, v16.4s, v2.s[0] \n" |
| | "fmla v20.4s, v17.4s, v0.s[1] \n" |
| | "fmla v21.4s, v17.4s, v2.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v22.4s, v18.4s, v0.s[2] \n" |
| | "fmla v23.4s, v18.4s, v2.s[2] \n" |
| | "fmla v20.4s, v19.4s, v0.s[3] \n" |
| | "fmla v21.4s, v19.4s, v2.s[3] \n" |
| | |
| | "prfm pldl1keep, [%3, #128] \n" |
| | "ld1 {v4.4s}, [%3] \n" |
| | |
| | "fmla v22.4s, v24.4s, v1.s[0] \n" |
| | "fmla v23.4s, v24.4s, v3.s[0] \n" |
| | "fmla v20.4s, v25.4s, v1.s[1] \n" |
| | "fmla v21.4s, v25.4s, v3.s[1] \n" |
| | |
| | |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4] \n" |
| | |
| | "fmla v22.4s, v26.4s, v1.s[2] \n" |
| | "fmla v23.4s, v26.4s, v3.s[2] \n" |
| | "fmla v20.4s, v27.4s, v1.s[3] \n" |
| | "fmla v21.4s, v27.4s, v3.s[3] \n" |
| | |
| | "fmla v22.4s, v16.4s, v2.s[0] \n" |
| | "fmla v23.4s, v16.4s, v4.s[0] \n" |
| | "fmla v20.4s, v17.4s, v2.s[1] \n" |
| | "fmla v21.4s, v17.4s, v4.s[1] \n" |
| | "fmla v22.4s, v18.4s, v2.s[2] \n" |
| | "fmla v23.4s, v18.4s, v4.s[2] \n" |
| | "fmla v20.4s, v19.4s, v2.s[3] \n" |
| | "fmla v21.4s, v19.4s, v4.s[3] \n" |
| | |
| | "fadd v20.4s, v20.4s, v22.4s \n" |
| | "fadd v21.4s, v21.4s, v23.4s \n" |
| | |
| | "sub %4, %4, #512 \n" |
| | |
| | "st1 {v20.4s, v21.4s}, [%0], #32 \n" |
| | |
| | : "=r"(outptr0), |
| | "=r"(r0), |
| | "=r"(r1), |
| | "=r"(r2), |
| | "=r"(kptr) |
| | : "0"(outptr0), |
| | "1"(r0), |
| | "2"(r1), |
| | "3"(r2), |
| | "4"(kptr) |
| | : "memory", "v0", "v1", "v2", "v3", "v4", "v5", "v6", "v16", "v17", "v18", "v19", "v20", "v21", "v22", "v23", "v24", "v25", "v26", "v27"); |
| | #else |
| | asm volatile( |
| | "pld [%0, #256] \n" |
| | "vld1.f32 {d24-d27}, [%0 :128] \n" |
| | |
| | "pld [%1, #512] \n" |
| | "vldm %1!, {d0-d7} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmul.f32 q14, q8, d0[0] \n" |
| | "vmul.f32 q15, q8, d4[0] \n" |
| | "vmla.f32 q12, q9, d0[1] \n" |
| | "vmla.f32 q13, q9, d4[1] \n" |
| | "vmla.f32 q14, q10, d1[0] \n" |
| | "vmla.f32 q15, q10, d5[0] \n" |
| | "vmla.f32 q12, q11, d1[1] \n" |
| | "vmla.f32 q13, q11, d5[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "pld [%1, #128] \n" |
| | "vld1.f32 {d8-d9}, [%1 :128] \n" |
| | |
| | "vmla.f32 q14, q8, d2[0] \n" |
| | "vmla.f32 q15, q8, d6[0] \n" |
| | "vmla.f32 q12, q9, d2[1] \n" |
| | "vmla.f32 q13, q9, d6[1] \n" |
| | "vmla.f32 q14, q10, d3[0] \n" |
| | "vmla.f32 q15, q10, d7[0] \n" |
| | "vmla.f32 q12, q11, d3[1] \n" |
| | "vmla.f32 q13, q11, d7[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q14, q8, d4[0] \n" |
| | "vmla.f32 q15, q8, d8[0] \n" |
| | "vmla.f32 q12, q9, d4[1] \n" |
| | "vmla.f32 q13, q9, d8[1] \n" |
| | "vmla.f32 q14, q10, d5[0] \n" |
| | "vmla.f32 q15, q10, d9[0] \n" |
| | "vmla.f32 q12, q11, d5[1] \n" |
| | "vmla.f32 q13, q11, d9[1] \n" |
| | |
| | "pld [%2, #512] \n" |
| | "vldm %2!, {d0-d7} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q14, q8, d0[0] \n" |
| | "vmla.f32 q15, q8, d4[0] \n" |
| | "vmla.f32 q12, q9, d0[1] \n" |
| | "vmla.f32 q13, q9, d4[1] \n" |
| | "vmla.f32 q14, q10, d1[0] \n" |
| | "vmla.f32 q15, q10, d5[0] \n" |
| | "vmla.f32 q12, q11, d1[1] \n" |
| | "vmla.f32 q13, q11, d5[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "pld [%2, #128] \n" |
| | "vld1.f32 {d8-d9}, [%2 :128] \n" |
| | |
| | "vmla.f32 q14, q8, d2[0] \n" |
| | "vmla.f32 q15, q8, d6[0] \n" |
| | "vmla.f32 q12, q9, d2[1] \n" |
| | "vmla.f32 q13, q9, d6[1] \n" |
| | "vmla.f32 q14, q10, d3[0] \n" |
| | "vmla.f32 q15, q10, d7[0] \n" |
| | "vmla.f32 q12, q11, d3[1] \n" |
| | "vmla.f32 q13, q11, d7[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q14, q8, d4[0] \n" |
| | "vmla.f32 q15, q8, d8[0] \n" |
| | "vmla.f32 q12, q9, d4[1] \n" |
| | "vmla.f32 q13, q9, d8[1] \n" |
| | "vmla.f32 q14, q10, d5[0] \n" |
| | "vmla.f32 q15, q10, d9[0] \n" |
| | "vmla.f32 q12, q11, d5[1] \n" |
| | "vmla.f32 q13, q11, d9[1] \n" |
| | |
| | "pld [%3, #512] \n" |
| | "vldm %3!, {d0-d7} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q14, q8, d0[0] \n" |
| | "vmla.f32 q15, q8, d4[0] \n" |
| | "vmla.f32 q12, q9, d0[1] \n" |
| | "vmla.f32 q13, q9, d4[1] \n" |
| | "vmla.f32 q14, q10, d1[0] \n" |
| | "vmla.f32 q15, q10, d5[0] \n" |
| | "vmla.f32 q12, q11, d1[1] \n" |
| | "vmla.f32 q13, q11, d5[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "pld [%3, #128] \n" |
| | "vld1.f32 {d8-d9}, [%3 :128] \n" |
| | |
| | "vmla.f32 q14, q8, d2[0] \n" |
| | "vmla.f32 q15, q8, d6[0] \n" |
| | "vmla.f32 q12, q9, d2[1] \n" |
| | "vmla.f32 q13, q9, d6[1] \n" |
| | "vmla.f32 q14, q10, d3[0] \n" |
| | "vmla.f32 q15, q10, d7[0] \n" |
| | "vmla.f32 q12, q11, d3[1] \n" |
| | "vmla.f32 q13, q11, d7[1] \n" |
| | |
| | |
| | "vldm %4, {d16-d23} \n" |
| | |
| | "vmla.f32 q14, q8, d4[0] \n" |
| | "vmla.f32 q15, q8, d8[0] \n" |
| | "vmla.f32 q12, q9, d4[1] \n" |
| | "vmla.f32 q13, q9, d8[1] \n" |
| | "vmla.f32 q14, q10, d5[0] \n" |
| | "vmla.f32 q15, q10, d9[0] \n" |
| | "vmla.f32 q12, q11, d5[1] \n" |
| | "vmla.f32 q13, q11, d9[1] \n" |
| | |
| | "vadd.f32 q12, q12, q14 \n" |
| | "vadd.f32 q13, q13, q15 \n" |
| | |
| | "sub %4, %4, #512 \n" |
| | |
| | "vst1.f32 {d24-d27}, [%0 :128]! \n" |
| | |
| | : "=r"(outptr0), |
| | "=r"(r0), |
| | "=r"(r1), |
| | "=r"(r2), |
| | "=r"(kptr) |
| | : "0"(outptr0), |
| | "1"(r0), |
| | "2"(r1), |
| | "3"(r2), |
| | "4"(kptr) |
| | : "memory", "q0", "q1", "q2", "q3", "q4", "q5", "q6", "q7", "q8", "q9", "q10", "q11", "q12", "q13", "q14", "q15"); |
| | #endif |
| | } |
| | for (; j < outw; j++) |
| | { |
| | #if __aarch64__ |
| | asm volatile( |
| | "prfm pldl1keep, [%0, #128] \n" |
| | "ld1 {v20.4s}, [%0] \n" |
| | |
| | "prfm pldl1keep, [%1, #384] \n" |
| | "ld1 {v0.4s, v1.4s, v2.4s}, [%1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmul v21.4s, v16.4s, v0.s[0] \n" |
| | "fmul v22.4s, v17.4s, v0.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmul v23.4s, v18.4s, v0.s[2] \n" |
| | "fmla v20.4s, v19.4s, v0.s[3] \n" |
| | |
| | "fmla v21.4s, v24.4s, v1.s[0] \n" |
| | "fmla v22.4s, v25.4s, v1.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v23.4s, v26.4s, v1.s[2] \n" |
| | "fmla v20.4s, v27.4s, v1.s[3] \n" |
| | |
| | "prfm pldl1keep, [%2, #384] \n" |
| | "ld1 {v3.4s, v4.4s, v5.4s}, [%2] \n" |
| | |
| | "fmla v21.4s, v16.4s, v2.s[0] \n" |
| | "fmla v22.4s, v17.4s, v2.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v23.4s, v18.4s, v2.s[2] \n" |
| | "fmla v20.4s, v19.4s, v2.s[3] \n" |
| | |
| | "fmla v21.4s, v24.4s, v3.s[0] \n" |
| | "fmla v22.4s, v25.4s, v3.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v23.4s, v26.4s, v3.s[2] \n" |
| | "fmla v20.4s, v27.4s, v3.s[3] \n" |
| | |
| | "fmla v21.4s, v16.4s, v4.s[0] \n" |
| | "fmla v22.4s, v17.4s, v4.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v23.4s, v18.4s, v4.s[2] \n" |
| | "fmla v20.4s, v19.4s, v4.s[3] \n" |
| | |
| | "prfm pldl1keep, [%3, #384] \n" |
| | "ld1 {v0.4s, v1.4s, v2.4s}, [%3] \n" |
| | |
| | "fmla v21.4s, v24.4s, v5.s[0] \n" |
| | "fmla v22.4s, v25.4s, v5.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4], #64 \n" |
| | |
| | "fmla v23.4s, v26.4s, v5.s[2] \n" |
| | "fmla v20.4s, v27.4s, v5.s[3] \n" |
| | |
| | "fmla v21.4s, v16.4s, v0.s[0] \n" |
| | "fmla v22.4s, v17.4s, v0.s[1] \n" |
| | |
| | "prfm pldl1keep, [%4, #512] \n" |
| | "ld1 {v24.4s, v25.4s, v26.4s, v27.4s}, [%4], #64 \n" |
| | |
| | "fmla v23.4s, v18.4s, v0.s[2] \n" |
| | "fmla v20.4s, v19.4s, v0.s[3] \n" |
| | |
| | "fmla v21.4s, v24.4s, v1.s[0] \n" |
| | "fmla v22.4s, v25.4s, v1.s[1] \n" |
| | |
| | |
| | "ld1 {v16.4s, v17.4s, v18.4s, v19.4s}, [%4] \n" |
| | |
| | "fmla v23.4s, v26.4s, v1.s[2] \n" |
| | "fmla v20.4s, v27.4s, v1.s[3] \n" |
| | |
| | "fmla v21.4s, v16.4s, v2.s[0] \n" |
| | "fmla v22.4s, v17.4s, v2.s[1] \n" |
| | "fmla v23.4s, v18.4s, v2.s[2] \n" |
| | "fmla v20.4s, v19.4s, v2.s[3] \n" |
| | |
| | "add %1, %1, #32 \n" |
| | |
| | "fadd v22.4s, v21.4s, v22.4s \n" |
| | |
| | "add %2, %2, #32 \n" |
| | |
| | "fadd v23.4s, v23.4s, v22.4s \n" |
| | |
| | "add %3, %3, #32 \n" |
| | |
| | "fadd v20.4s, v20.4s, v23.4s \n" |
| | |
| | "sub %4, %4, #512 \n" |
| | |
| | "st1 {v20.4s}, [%0], #16 \n" |
| | |
| | : "=r"(outptr0), |
| | "=r"(r0), |
| | "=r"(r1), |
| | "=r"(r2), |
| | "=r"(kptr) |
| | : "0"(outptr0), |
| | "1"(r0), |
| | "2"(r1), |
| | "3"(r2), |
| | "4"(kptr) |
| | : "memory", "v0", "v1", "v2", "v3", "v4", "v5", "v16", "v17", "v18", "v19", "v20", "v21", "v22", "v23", "v24", "v25", "v26", "v27"); |
| | #else |
| | asm volatile( |
| | "pld [%0, #128] \n" |
| | "vld1.f32 {d24-d25}, [%0 :128] \n" |
| | |
| | "pld [%1, #384] \n" |
| | "vldm %1, {d0-d5} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmul.f32 q13, q8, d0[0] \n" |
| | "vmul.f32 q14, q9, d0[1] \n" |
| | "vmul.f32 q15, q10, d1[0] \n" |
| | "vmla.f32 q12, q11, d1[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q13, q8, d2[0] \n" |
| | "vmla.f32 q14, q9, d2[1] \n" |
| | "vmla.f32 q15, q10, d3[0] \n" |
| | "vmla.f32 q12, q11, d3[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q13, q8, d4[0] \n" |
| | "vmla.f32 q14, q9, d4[1] \n" |
| | "vmla.f32 q15, q10, d5[0] \n" |
| | "vmla.f32 q12, q11, d5[1] \n" |
| | |
| | "pld [%2, #384] \n" |
| | "vldm %2, {d0-d5} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q13, q8, d0[0] \n" |
| | "vmla.f32 q14, q9, d0[1] \n" |
| | "vmla.f32 q15, q10, d1[0] \n" |
| | "vmla.f32 q12, q11, d1[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q13, q8, d2[0] \n" |
| | "vmla.f32 q14, q9, d2[1] \n" |
| | "vmla.f32 q15, q10, d3[0] \n" |
| | "vmla.f32 q12, q11, d3[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q13, q8, d4[0] \n" |
| | "vmla.f32 q14, q9, d4[1] \n" |
| | "vmla.f32 q15, q10, d5[0] \n" |
| | "vmla.f32 q12, q11, d5[1] \n" |
| | |
| | "pld [%3, #384] \n" |
| | "vldm %3, {d0-d5} \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q13, q8, d0[0] \n" |
| | "vmla.f32 q14, q9, d0[1] \n" |
| | "vmla.f32 q15, q10, d1[0] \n" |
| | "vmla.f32 q12, q11, d1[1] \n" |
| | |
| | "pld [%4, #512] \n" |
| | "vldm %4!, {d16-d23} \n" |
| | |
| | "vmla.f32 q13, q8, d2[0] \n" |
| | "vmla.f32 q14, q9, d2[1] \n" |
| | "vmla.f32 q15, q10, d3[0] \n" |
| | "vmla.f32 q12, q11, d3[1] \n" |
| | |
| | |
| | "vldm %4, {d16-d23} \n" |
| | |
| | "vmla.f32 q13, q8, d4[0] \n" |
| | "vmla.f32 q14, q9, d4[1] \n" |
| | "vmla.f32 q15, q10, d5[0] \n" |
| | "vmla.f32 q12, q11, d5[1] \n" |
| | |
| | "vadd.f32 q14, q14, q13 \n" |
| | |
| | "add %1, %1, #32 \n" |
| | |
| | "vadd.f32 q15, q15, q14 \n" |
| | |
| | "add %2, %2, #32 \n" |
| | |
| | "vadd.f32 q12, q12, q15 \n" |
| | |
| | "add %3, %3, #32 \n" |
| | |
| | "sub %4, %4, #512 \n" |
| | |
| | "vst1.f32 {d24-d25}, [%0 :128]! \n" |
| | |
| | : "=r"(outptr0), |
| | "=r"(r0), |
| | "=r"(r1), |
| | "=r"(r2), |
| | "=r"(kptr) |
| | : "0"(outptr0), |
| | "1"(r0), |
| | "2"(r1), |
| | "3"(r2), |
| | "4"(kptr) |
| | : "memory", "q0", "q1", "q2", "q3", "q4", "q5", "q6", "q7", "q8", "q9", "q10", "q11", "q12", "q13", "q14", "q15"); |
| | #endif |
| | } |
| |
|
| | r0 += tailstep; |
| | r1 += tailstep; |
| | r2 += tailstep; |
| | } |
| | } |
| | } |
| | } |
| |
|