|  | /* | 
|  | * Copyright (c) 2016, Alliance for Open Media. All rights reserved | 
|  | * | 
|  | * This source code is subject to the terms of the BSD 2 Clause License and | 
|  | * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License | 
|  | * was not distributed with this source code in the LICENSE file, you can | 
|  | * obtain it at www.aomedia.org/license/software. If the Alliance for Open | 
|  | * Media Patent License 1.0 was not distributed with this source code in the | 
|  | * PATENTS file, you can obtain it at www.aomedia.org/license/patent. | 
|  | */ | 
|  |  | 
|  | #include "./aom_config.h" | 
|  | #include "./aom_rtcd.h" | 
|  |  | 
|  | #include "third_party/googletest/src/googletest/include/gtest/gtest.h" | 
|  |  | 
|  | #include "test/clear_system_state.h" | 
|  | #include "test/register_state_check.h" | 
|  | #include "aom/aom_integer.h" | 
|  |  | 
|  | typedef void (*IdctFunc)(int16_t *input, unsigned char *pred_ptr, | 
|  | int pred_stride, unsigned char *dst_ptr, | 
|  | int dst_stride); | 
|  | namespace { | 
|  | class IDCTTest : public ::testing::TestWithParam<IdctFunc> { | 
|  | protected: | 
|  | virtual void SetUp() { | 
|  | int i; | 
|  |  | 
|  | UUT = GetParam(); | 
|  | memset(input, 0, sizeof(input)); | 
|  | /* Set up guard blocks */ | 
|  | for (i = 0; i < 256; i++) output[i] = ((i & 0xF) < 4 && (i < 64)) ? 0 : -1; | 
|  | } | 
|  |  | 
|  | virtual void TearDown() { libaom_test::ClearSystemState(); } | 
|  |  | 
|  | IdctFunc UUT; | 
|  | int16_t input[16]; | 
|  | unsigned char output[256]; | 
|  | unsigned char predict[256]; | 
|  | }; | 
|  |  | 
|  | TEST_P(IDCTTest, TestGuardBlocks) { | 
|  | int i; | 
|  |  | 
|  | for (i = 0; i < 256; i++) | 
|  | if ((i & 0xF) < 4 && i < 64) | 
|  | EXPECT_EQ(0, output[i]) << i; | 
|  | else | 
|  | EXPECT_EQ(255, output[i]); | 
|  | } | 
|  |  | 
|  | TEST_P(IDCTTest, TestAllZeros) { | 
|  | int i; | 
|  |  | 
|  | ASM_REGISTER_STATE_CHECK(UUT(input, output, 16, output, 16)); | 
|  |  | 
|  | for (i = 0; i < 256; i++) | 
|  | if ((i & 0xF) < 4 && i < 64) | 
|  | EXPECT_EQ(0, output[i]) << "i==" << i; | 
|  | else | 
|  | EXPECT_EQ(255, output[i]) << "i==" << i; | 
|  | } | 
|  |  | 
|  | TEST_P(IDCTTest, TestAllOnes) { | 
|  | int i; | 
|  |  | 
|  | input[0] = 4; | 
|  | ASM_REGISTER_STATE_CHECK(UUT(input, output, 16, output, 16)); | 
|  |  | 
|  | for (i = 0; i < 256; i++) | 
|  | if ((i & 0xF) < 4 && i < 64) | 
|  | EXPECT_EQ(1, output[i]) << "i==" << i; | 
|  | else | 
|  | EXPECT_EQ(255, output[i]) << "i==" << i; | 
|  | } | 
|  |  | 
|  | TEST_P(IDCTTest, TestAddOne) { | 
|  | int i; | 
|  |  | 
|  | for (i = 0; i < 256; i++) predict[i] = i; | 
|  | input[0] = 4; | 
|  | ASM_REGISTER_STATE_CHECK(UUT(input, predict, 16, output, 16)); | 
|  |  | 
|  | for (i = 0; i < 256; i++) | 
|  | if ((i & 0xF) < 4 && i < 64) | 
|  | EXPECT_EQ(i + 1, output[i]) << "i==" << i; | 
|  | else | 
|  | EXPECT_EQ(255, output[i]) << "i==" << i; | 
|  | } | 
|  |  | 
|  | TEST_P(IDCTTest, TestWithData) { | 
|  | int i; | 
|  |  | 
|  | for (i = 0; i < 16; i++) input[i] = i; | 
|  |  | 
|  | ASM_REGISTER_STATE_CHECK(UUT(input, output, 16, output, 16)); | 
|  |  | 
|  | for (i = 0; i < 256; i++) | 
|  | if ((i & 0xF) > 3 || i > 63) | 
|  | EXPECT_EQ(255, output[i]) << "i==" << i; | 
|  | else if (i == 0) | 
|  | EXPECT_EQ(11, output[i]) << "i==" << i; | 
|  | else if (i == 34) | 
|  | EXPECT_EQ(1, output[i]) << "i==" << i; | 
|  | else if (i == 2 || i == 17 || i == 32) | 
|  | EXPECT_EQ(3, output[i]) << "i==" << i; | 
|  | else | 
|  | EXPECT_EQ(0, output[i]) << "i==" << i; | 
|  | } | 
|  |  | 
|  | INSTANTIATE_TEST_CASE_P(C, IDCTTest, ::testing::Values(aom_short_idct4x4llm_c)); | 
|  | #if HAVE_MMX | 
|  | INSTANTIATE_TEST_CASE_P(MMX, IDCTTest, | 
|  | ::testing::Values(aom_short_idct4x4llm_mmx)); | 
|  | #endif | 
|  | #if HAVE_MSA | 
|  | INSTANTIATE_TEST_CASE_P(MSA, IDCTTest, | 
|  | ::testing::Values(aom_short_idct4x4llm_msa)); | 
|  | #endif | 
|  | } |