InfiniteLoop.cpp revision dcecc0c8d22e894525e25a122ce25129b51338f2
1dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo#include <thread> 2dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo#include <chrono> 3dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 4dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo#include <RenderScript.h> 5dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 6dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo#include "ScriptC_simple.h" 7dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 8dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leousing namespace android; 9dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leousing namespace RSC; 10dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 11dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leoint main() 12dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo{ 13dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo static const int size = 64; 14dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo sp<RS> rs = new RS(); 15dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 16dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo rs->init("/data/rscache", RS_INIT_LOW_LATENCY); 17dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 18dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo auto e = Element::RGBA_8888(rs); 19dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo Type::Builder tb(rs, e); 20dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo tb.setX(size); 21dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo tb.setY(size); 22dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo auto t = tb.create(); 23dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 24dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo auto a = Allocation::createTyped(rs, t); 25dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo auto b = Allocation::createTyped(rs, t); 26dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 27dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo sp<ScriptC_simple> s = new ScriptC_simple(rs); 28dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 29dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo // Test is designed to loop forever, waits for two seconds 30dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo // between each invocation of the kernel 31dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo bool forever = true; 32dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo while(forever) 33dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo { 34dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo s->forEach_simple_kernel(a, b); 35dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo std::this_thread::sleep_for(std::chrono::seconds(2)); 36dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo } 37dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 38dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo uint32_t * output = new uint32_t[size*size]; 39dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo b->copy2DRangeTo(0, 0, size, size, output); 40dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo delete [] output; 41dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 42dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo return 0; 43dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo} 44dcecc0c8d22e894525e25a122ce25129b51338f2Dean De Leo 45