blob: 7a93b2e5a079a565a4d0520d6e04cccbb0a39e28 [file] [log] [blame]
// This file is automatically generated from
// frameworks/rs/tests/java_api/RSUnitTests/RSUnitTests.py
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "shared.rsh"
rs_allocation A;
rs_allocation B;
uint32_t gDimX, gDimY;
static bool failed = false;
void init_vars(int *out) {
*out = 7;
}
void xform(const int *in, int *out, rs_kernel_context context, uint32_t x, uint32_t y) {
if (!_RS_ASSERT_EQU(*in, 7))
rsDebug("xform at x, y", x, y);
uint32_t dimX = rsGetDimX(context);
uint32_t dimY = rsGetDimY(context);
_RS_ASSERT_EQU(dimX, gDimX);
_RS_ASSERT_EQU(dimY, gDimY);
*out = *in + x + dimX * y;
}
static bool test_xform_output() {
bool failed = false;
int i, j;
for (i = 0; i < gDimX; i++) {
for (j = 0; j < gDimY; j++) {
int bElt = rsGetElementAt_int(B, i, j);
int aElt = rsGetElementAt_int(A, i, j);
if (!_RS_ASSERT_EQU(bElt, (aElt + i + gDimX * j)))
rsDebug("test_xform_output at i, j", i, j);
}
}
if (failed) {
rsDebug("kernel2d (old style) test_xform_output FAILED", 0);
}
else {
rsDebug("kernel2d (old style) test_xform_output PASSED", 0);
}
return failed;
}
void verify_xform() {
failed |= test_xform_output();
}
void kernel_test() {
if (failed) {
rsSendToClientBlocking(RS_MSG_TEST_FAILED);
}
else {
rsSendToClientBlocking(RS_MSG_TEST_PASSED);
}
}