sglang_v0.5.2/pytorch_2.8.0/third_party/XNNPACK/bench/x16-packw.cc

33 lines
940 B
C++

// Copyright 2024 Google LLC
//
// This source code is licensed under the BSD-style license found in the
// LICENSE file in the root directory of this source tree.
#include <benchmark/benchmark.h>
#include "bgemm.h"
#include "packw-benchmark.h"
#include "utils.h"
#include "xnnpack/common.h"
#include "xnnpack/hardware-config.h"
#include "xnnpack/packw.h"
static void x16_packw(benchmark::State& state, const char* net,
xnn_x16_packw_gemm_goi_ukernel_fn ukernel,
uint64_t arch_flags, size_t nr, size_t kr, size_t sr) {
benchmark::utils::CheckArchFlags(state, arch_flags);
x16_packw(state, ukernel, nr, kr, sr);
}
#define XNN_UKERNEL(arch_flags, ukernel, nr, kr, sr, kblock, nr_scale) \
BENCHMARK_CAPTURE_BGEMM(x16_packw, ukernel##_, ukernel, arch_flags, nr, kr, sr);
#include "x16-packw/x16-packw.h"
#undef XNN_UKERNEL
#ifndef XNNPACK_BENCHMARK_NO_MAIN
BENCHMARK_MAIN();
#endif