mirror of
https://github.com/zebrajr/opencv.git
synced 2025-12-06 00:19:46 +01:00
Enabled fp16 conversions, but disabled NEON FP16 arithmetics on Windows for ARM for now #27897 ### Pull Request Readiness Checklist See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [x] I agree to contribute to the project under Apache 2 License. - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [ ] The PR is proposed to the proper branch - [ ] There is a reference to the original bug report and related work - [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [ ] The feature is well documented and sample code can be built with the project CMake
27 lines
681 B
C++
27 lines
681 B
C++
#include <stdio.h>
|
|
|
|
#if (defined __GNUC__ && (defined __arm__ || defined __aarch64__))/* || (defined _MSC_VER && (defined _M_ARM64 || defined _M_ARM64EC)) */
|
|
// Windows + ARM64 case disabled: https://github.com/opencv/opencv/issues/25052
|
|
|
|
#include "arm_neon.h"
|
|
int test()
|
|
{
|
|
const unsigned int src[] = { 0, 0, 0, 0 };
|
|
unsigned int dst[4];
|
|
uint32x4_t v_src = *(uint32x4_t*)src;
|
|
uint8x16_t v_m0 = *(uint8x16_t*)src;
|
|
uint8x16_t v_m1 = *(uint8x16_t*)src;
|
|
uint32x4_t v_dst = vdotq_u32(v_src, v_m0, v_m1);
|
|
*(uint32x4_t*)dst = v_dst;
|
|
return (int)dst[0];
|
|
}
|
|
#else
|
|
#error "DOTPROD is not supported"
|
|
#endif
|
|
|
|
int main()
|
|
{
|
|
printf("%d\n", test());
|
|
return 0;
|
|
}
|