| /* | 
 |  * 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 | 
 | } |