blob: 94bfe4275abee642a74470fbb2dbacda5d5fbc46 [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 {
34 for (uint32_t ct = 0; ct < mRSC->mStateRaster.mRasterPrograms.size(); ct++) {
35 if (mRSC->mStateRaster.mRasterPrograms[ct] == this) {
36 mRSC->mStateRaster.mRasterPrograms.removeAt(ct);
37 break;
38 }
39 }
40}
41
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080042ProgramRaster::~ProgramRaster() {
Jason Sams721acc42011-04-06 11:23:54 -070043 mRSC->mHal.funcs.raster.destroy(mRSC, this);
Jason Sams5fd09d82009-09-23 13:57:02 -070044}
45
Jason Sams721acc42011-04-06 11:23:54 -070046void ProgramRaster::setup(const Context *rsc, ProgramRasterState *state) {
Alex Sakhartchoukd18c7442010-07-12 15:50:32 -070047 if (state->mLast.get() == this && !mDirty) {
Jason Samsc460e552009-11-25 13:22:07 -080048 return;
49 }
50 state->mLast.set(this);
Alex Sakhartchoukd18c7442010-07-12 15:50:32 -070051 mDirty = false;
52
Jason Sams721acc42011-04-06 11:23:54 -070053 rsc->mHal.funcs.raster.setActive(rsc, this);
Jason Samsc460e552009-11-25 13:22:07 -080054}
55
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080056void ProgramRaster::serialize(OStream *stream) const {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070057}
Jason Sams5fd09d82009-09-23 13:57:02 -070058
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080059ProgramRaster *ProgramRaster::createFromStream(Context *rsc, IStream *stream) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070060 return NULL;
61}
Jason Sams5fd09d82009-09-23 13:57:02 -070062
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080063ProgramRasterState::ProgramRasterState() {
Jason Sams5fd09d82009-09-23 13:57:02 -070064}
65
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080066ProgramRasterState::~ProgramRasterState() {
Jason Sams5fd09d82009-09-23 13:57:02 -070067}
68
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080069void ProgramRasterState::init(Context *rsc) {
Jason Sams5b9f3e22011-09-23 14:18:53 -070070 mDefault.set(ProgramRaster::getProgramRaster(rsc, false, RS_CULL_BACK).get());
Jason Sams5fd09d82009-09-23 13:57:02 -070071}
72
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080073void ProgramRasterState::deinit(Context *rsc) {
Jason Samsf2649a92009-09-25 16:37:33 -070074 mDefault.clear();
75 mLast.clear();
76}
77
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070078ObjectBaseRef<ProgramRaster> ProgramRaster::getProgramRaster(Context *rsc,
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070079 bool pointSprite,
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070080 RsCullMode cull) {
81 ObjectBaseRef<ProgramRaster> returnRef;
82 ObjectBase::asyncLock();
83 for (uint32_t ct = 0; ct < rsc->mStateRaster.mRasterPrograms.size(); ct++) {
84 ProgramRaster *existing = rsc->mStateRaster.mRasterPrograms[ct];
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070085 if (existing->mHal.state.pointSprite != pointSprite) continue;
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070086 if (existing->mHal.state.cull != cull) continue;
87 returnRef.set(existing);
88 ObjectBase::asyncUnlock();
89 return returnRef;
90 }
91 ObjectBase::asyncUnlock();
92
Jason Sams5b9f3e22011-09-23 14:18:53 -070093 ProgramRaster *pr = new ProgramRaster(rsc, pointSprite, cull);
Alex Sakhartchoukc700e642011-08-16 13:09:46 -070094 returnRef.set(pr);
95
96 ObjectBase::asyncLock();
97 rsc->mStateRaster.mRasterPrograms.push(pr);
98 ObjectBase::asyncUnlock();
99
100 return returnRef;
101}
102
Jason Sams5fd09d82009-09-23 13:57:02 -0700103namespace android {
104namespace renderscript {
105
Jason Sams5b9f3e22011-09-23 14:18:53 -0700106RsProgramRaster rsi_ProgramRasterCreate(Context * rsc, bool pointSprite, RsCullMode cull) {
107 ObjectBaseRef<ProgramRaster> pr = ProgramRaster::getProgramRaster(rsc, pointSprite, cull);
Jason Sams5fd09d82009-09-23 13:57:02 -0700108 pr->incUserRef();
Alex Sakhartchoukc700e642011-08-16 13:09:46 -0700109 return pr.get();
Jason Sams5fd09d82009-09-23 13:57:02 -0700110}
111
Jason Sams5fd09d82009-09-23 13:57:02 -0700112}
113}
114