blob: d47e588d0c236a6f4097d302e348698da1710dc3 [file] [log] [blame]
Jason Sams5fd09d82009-09-23 13:57:02 -07001/*
2 * Copyright (C) 2009 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include "rsContext.h"
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070018#include "rsProgramRaster.h"
Jason Sams5fd09d82009-09-23 13:57:02 -070019
20using namespace android;
21using namespace android::renderscript;
22
23
Jason Sams5b9f3e22011-09-23 14:18:53 -070024ProgramRaster::ProgramRaster(Context *rsc, bool pointSprite, RsCullMode cull)
Alex Sakhartchouk7f126c72011-05-05 16:56:27 -070025 : ProgramBase(rsc) {
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080026
Jason Sams721acc42011-04-06 11:23:54 -070027 memset(&mHal, 0, sizeof(mHal));
Jason Sams721acc42011-04-06 11:23:54 -070028 mHal.state.pointSprite = pointSprite;
Jason Sams721acc42011-04-06 11:23:54 -070029 mHal.state.cull = cull;
Jason Sams721acc42011-04-06 11:23:54 -070030 rsc->mHal.funcs.raster.init(rsc, this);
Jason Sams5fd09d82009-09-23 13:57:02 -070031}
32
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070033void ProgramRaster::preDestroy() const {
Chris Wailes93d6bc82014-07-28 16:54:38 -070034 auto &rasters = mRSC->mStateRaster.mRasterPrograms;
35
36 for (auto prIter = rasters.begin(), endIter = rasters.end();
37 prIter != endIter; prIter++) {
38
39 if (this == *prIter) {
40 rasters.erase(prIter);
41 return;
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070042 }
43 }
44}
45
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080046ProgramRaster::~ProgramRaster() {
Jason Sams721acc42011-04-06 11:23:54 -070047 mRSC->mHal.funcs.raster.destroy(mRSC, this);
Jason Sams5fd09d82009-09-23 13:57:02 -070048}
49
Jason Sams721acc42011-04-06 11:23:54 -070050void ProgramRaster::setup(const Context *rsc, ProgramRasterState *state) {
Alex Sakhartchoukd18c7442010-07-12 15:50:32 -070051 if (state->mLast.get() == this && !mDirty) {
Jason Samsc460e552009-11-25 13:22:07 -080052 return;
53 }
54 state->mLast.set(this);
Alex Sakhartchoukd18c7442010-07-12 15:50:32 -070055 mDirty = false;
56
Jason Sams721acc42011-04-06 11:23:54 -070057 rsc->mHal.funcs.raster.setActive(rsc, this);
Jason Samsc460e552009-11-25 13:22:07 -080058}
59
Jason Samse3150cf2012-07-24 18:10:20 -070060void ProgramRaster::serialize(Context *rsc, OStream *stream) const {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070061}
Jason Sams5fd09d82009-09-23 13:57:02 -070062
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080063ProgramRaster *ProgramRaster::createFromStream(Context *rsc, IStream *stream) {
Chris Wailes44bef6f2014-08-12 13:51:10 -070064 return nullptr;
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070065}
Jason Sams5fd09d82009-09-23 13:57:02 -070066
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080067ProgramRasterState::ProgramRasterState() {
Jason Sams5fd09d82009-09-23 13:57:02 -070068}
69
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080070ProgramRasterState::~ProgramRasterState() {
Jason Sams5fd09d82009-09-23 13:57:02 -070071}
72
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080073void ProgramRasterState::init(Context *rsc) {
Jason Sams5b9f3e22011-09-23 14:18:53 -070074 mDefault.set(ProgramRaster::getProgramRaster(rsc, false, RS_CULL_BACK).get());
Jason Sams5fd09d82009-09-23 13:57:02 -070075}
76
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080077void ProgramRasterState::deinit(Context *rsc) {
Jason Samsf2649a92009-09-25 16:37:33 -070078 mDefault.clear();
79 mLast.clear();
80}
81
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070082ObjectBaseRef<ProgramRaster> ProgramRaster::getProgramRaster(Context *rsc,
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070083 bool pointSprite,
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070084 RsCullMode cull) {
85 ObjectBaseRef<ProgramRaster> returnRef;
86 ObjectBase::asyncLock();
87 for (uint32_t ct = 0; ct < rsc->mStateRaster.mRasterPrograms.size(); ct++) {
88 ProgramRaster *existing = rsc->mStateRaster.mRasterPrograms[ct];
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070089 if (existing->mHal.state.pointSprite != pointSprite) continue;
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070090 if (existing->mHal.state.cull != cull) continue;
91 returnRef.set(existing);
92 ObjectBase::asyncUnlock();
93 return returnRef;
94 }
95 ObjectBase::asyncUnlock();
96
Jason Sams5b9f3e22011-09-23 14:18:53 -070097 ProgramRaster *pr = new ProgramRaster(rsc, pointSprite, cull);
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070098 returnRef.set(pr);
99
100 ObjectBase::asyncLock();
Chris Wailes93d6bc82014-07-28 16:54:38 -0700101 rsc->mStateRaster.mRasterPrograms.push_back(pr);
Alex Sakhartchoukc700e642011-08-16 13:09:46 -0700102 ObjectBase::asyncUnlock();
103
104 return returnRef;
105}
106
Jason Sams5fd09d82009-09-23 13:57:02 -0700107namespace android {
108namespace renderscript {
109
Jason Sams5b9f3e22011-09-23 14:18:53 -0700110RsProgramRaster rsi_ProgramRasterCreate(Context * rsc, bool pointSprite, RsCullMode cull) {
111 ObjectBaseRef<ProgramRaster> pr = ProgramRaster::getProgramRaster(rsc, pointSprite, cull);
Jason Sams5fd09d82009-09-23 13:57:02 -0700112 pr->incUserRef();
Alex Sakhartchoukc700e642011-08-16 13:09:46 -0700113 return pr.get();
Jason Sams5fd09d82009-09-23 13:57:02 -0700114}
115
Jason Sams5fd09d82009-09-23 13:57:02 -0700116}
117}