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