diff options
| author | Amlal El Mahrouss <amlal.elmahrouss@icloud.com> | 2025-09-17 10:06:21 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-09-17 10:06:21 +0200 |
| commit | 94799223495b9842bca67e1a6ecf611cec3ee771 (patch) | |
| tree | 435f5b6adb6889462640b1456e684360cd7e495f /dev/lib/simd | |
| parent | 6789dd7d88a192e3f55b95798cb393e7d12f368a (diff) | |
| parent | fa4748e414e9494442f9bcde9c659d3951af19c0 (diff) | |
(SCL: v1.0.44) Merge pull request #1 from snu-systems-corp/dev
SCL: v1.0.44
Diffstat (limited to 'dev/lib/simd')
| -rw-r--r-- | dev/lib/simd/basic_simd.hpp | 50 | ||||
| -rw-r--r-- | dev/lib/simd/simd.hpp | 60 |
2 files changed, 110 insertions, 0 deletions
diff --git a/dev/lib/simd/basic_simd.hpp b/dev/lib/simd/basic_simd.hpp new file mode 100644 index 0000000..d748d0c --- /dev/null +++ b/dev/lib/simd/basic_simd.hpp @@ -0,0 +1,50 @@ +/* + * File: simd/basic_simd.hpp + * Purpose: Basic SIMD backend C++ library. + * Author: Amlal El Mahrouss (founder@snu.systems) + * Copyright 2025, Amlal El Mahrouss, and SNU Systems, Corp, licensed under the BSL 1.0 license. + */ + +#pragma once + +#include <lib/core/includes.hpp> +#include <cmath> + +#ifdef __x86_64__ +#include <immintrin.h> + +using simd_type = __m256; +#endif + +#ifdef __aarch64__ +#include <arm_neon.h> + +using simd_type = float32x4_t; +#endif + +namespace ocl::snu::simd +{ + struct basic_simd_backend final + { + struct simd_traits final + { + simd_type __val; + + private: + static bool bad; + friend class basic_simd_backend; + }; + + using register_type = simd_traits; + + const bool& is_bad() noexcept + { + return register_type::bad; + } + + std::basic_string<char> isa() + { + return "basic-backend"; + } + }; +} // namespace ocl::snu::simd diff --git a/dev/lib/simd/simd.hpp b/dev/lib/simd/simd.hpp new file mode 100644 index 0000000..779d020 --- /dev/null +++ b/dev/lib/simd/simd.hpp @@ -0,0 +1,60 @@ +/* + * File: simd/simd.hpp + * Purpose: SIMD C++ library. + * Author: Amlal El Mahrouss (founder@snu.systems) + * Copyright 2025, Amlal El Mahrouss, and SNU Systems, Corp, licensed under the BSL 1.0 license. + */ + +#pragma once + +#include <lib/core/includes.hpp> + +/// @author Amlal El Mahrouss +/// @brief Basic SIMD processor. + +namespace ocl::snu::simd +{ + template <typename backend_type> + class basic_simd_processor + { + private: + backend_type processor_; + + enum opcode + { + bad, + add, + mul, + div, + }; + + public: + basic_simd_processor() = default; + virtual ~basic_simd_processor() = default; + + basic_simd_processor& operator=(const basic_simd_processor&) = delete; + basic_simd_processor(const basic_simd_processor&) = delete; + + typename backend_type::register_type& call(const opcode& op, typename backend_type::register_type& lhs, typename backend_type::register_type& rhs) + { + switch (op) + { + case add: + return processor_.add(lhs, rhs); + case mul: + return processor_.mul(lhs, rhs); + case div: + return processor_.div(lhs, rhs); + default: + break; + } + + return processor_.is_bad(); + } + + std::basic_string<char> isa() + { + return processor_.isa(); + } + }; +} // namespace ocl::snu::simd |
