blob: 20146719332614f0ae3fa313ac9755379529cc96 [file] [log] [blame]
mtklein281b33f2016-07-12 15:01:26 -07001/*
2 * Copyright 2016 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#include "Test.h"
Mike Klein9161ef02016-10-04 14:03:27 -04009#include "SkHalf.h"
mtklein281b33f2016-07-12 15:01:26 -070010#include "SkRasterPipeline.h"
11
mtklein281b33f2016-07-12 15:01:26 -070012DEF_TEST(SkRasterPipeline, r) {
Mike Klein9161ef02016-10-04 14:03:27 -040013 // Build and run a simple pipeline to exercise SkRasterPipeline,
14 // drawing 50% transparent blue over opaque red in half-floats.
mtklein281b33f2016-07-12 15:01:26 -070015
Mike Klein9161ef02016-10-04 14:03:27 -040016 Sk4h red = SkFloatToHalf_finite_ftz({ 1.0f, 0.0f, 0.0f, 1.0f }),
17 blue = SkFloatToHalf_finite_ftz({ 0.0f, 0.0f, 0.5f, 0.5f }),
Mike Kleinc876e992016-10-05 08:45:57 -040018 result = { 1, 2, 3, 4 };
mtklein281b33f2016-07-12 15:01:26 -070019
Mike Kleind0ccb572016-10-05 09:36:26 -040020 uint64_t bits;
21 memcpy(&bits, &red, 8);
22 SkDebugf("SkRasterPipeline red: 0x%016llx, want 0x3c00000000003c00\n", bits);
23 memcpy(&bits, &blue, 8);
24 SkDebugf("SkRasterPipeline blue: 0x%016llx, want 0x3800380000000000\n", bits);
25
mtklein281b33f2016-07-12 15:01:26 -070026 SkRasterPipeline p;
Mike Klein9161ef02016-10-04 14:03:27 -040027 p.append(SkRasterPipeline::load_s_f16, &blue);
28 p.append(SkRasterPipeline::load_d_f16, &red);
29 p.append(SkRasterPipeline::srcover);
30 p.append(SkRasterPipeline::store_f16, &result);
31 p.run(1);
mtklein281b33f2016-07-12 15:01:26 -070032
Mike Klein9161ef02016-10-04 14:03:27 -040033 Sk4f f = SkHalfToFloat_finite_ftz(result);
mtklein281b33f2016-07-12 15:01:26 -070034
Mike Klein85a45d92016-10-04 19:41:56 -040035 memcpy(&bits, &result, 8);
Mike Kleind0ccb572016-10-05 09:36:26 -040036 SkDebugf("SkRasterPipeline result: 0x%016llx, want 0x3c00380000003800\n", bits);
Mike Klein85a45d92016-10-04 19:41:56 -040037
Mike Klein9161ef02016-10-04 14:03:27 -040038 // We should see half-intensity magenta.
39 REPORTER_ASSERT(r, f[0] == 0.5f);
40 REPORTER_ASSERT(r, f[1] == 0.0f);
41 REPORTER_ASSERT(r, f[2] == 0.5f);
42 REPORTER_ASSERT(r, f[3] == 1.0f);
mtklein281b33f2016-07-12 15:01:26 -070043}
mtklein0abddf72016-07-13 08:22:20 -070044
45DEF_TEST(SkRasterPipeline_empty, r) {
46 // No asserts... just a test that this is safe to run.
47 SkRasterPipeline p;
48 p.run(20);
49}
50
51DEF_TEST(SkRasterPipeline_nonsense, r) {
52 // No asserts... just a test that this is safe to run and terminates.
Mike Klein9161ef02016-10-04 14:03:27 -040053 // srcover() calls st->next(); this makes sure we've always got something there to call.
mtklein0abddf72016-07-13 08:22:20 -070054 SkRasterPipeline p;
Mike Klein9161ef02016-10-04 14:03:27 -040055 p.append(SkRasterPipeline::srcover);
mtklein0abddf72016-07-13 08:22:20 -070056 p.run(20);
57}