blob: 527b3d7dbabbb769187463c38a3a04d070575512 [file] [log] [blame]
Jason Sams326e0dd2009-05-22 14:03:28 -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"
18
Jason Sams326e0dd2009-05-22 14:03:28 -070019#include "rsThreadIO.h"
20
21using namespace android;
22using namespace android::renderscript;
23
Jason Sams326e0dd2009-05-22 14:03:28 -070024ThreadIO::ThreadIO()
25{
26 mToCore.init(16 * 1024);
Jason Sams8c401ef2009-10-06 13:58:47 -070027 mToClient.init(1024);
Jason Sams326e0dd2009-05-22 14:03:28 -070028}
29
30ThreadIO::~ThreadIO()
31{
32}
33
Jason Sams8c0ee652009-08-25 14:49:07 -070034void ThreadIO::shutdown()
35{
36 mToCore.shutdown();
37}
38
Jason Sams732f1c02009-06-18 16:58:42 -070039bool ThreadIO::playCoreCommands(Context *con, bool waitForCommand)
Jason Sams326e0dd2009-05-22 14:03:28 -070040{
Jason Samsa44cb292009-06-04 17:58:03 -070041 bool ret = false;
Jason Sams732f1c02009-06-18 16:58:42 -070042 while(!mToCore.isEmpty() || waitForCommand) {
Jason Sams24371d92009-08-19 12:17:14 -070043 uint32_t cmdID = 0;
44 uint32_t cmdSize = 0;
Jason Samsa44cb292009-06-04 17:58:03 -070045 ret = true;
Jason Sams1fddd902009-09-25 15:25:00 -070046 if (con->props.mLogTimes) {
Joe Onorato76371ff2009-09-23 16:37:36 -070047 con->timerSet(Context::RS_TIMER_IDLE);
48 }
Jason Sams326e0dd2009-05-22 14:03:28 -070049 const void * data = mToCore.get(&cmdID, &cmdSize);
Jason Samse514b452009-09-25 14:51:22 -070050 if (!cmdSize) {
51 // exception occured, probably shutdown.
52 return false;
53 }
Jason Sams1fddd902009-09-25 15:25:00 -070054 if (con->props.mLogTimes) {
Joe Onorato76371ff2009-09-23 16:37:36 -070055 con->timerSet(Context::RS_TIMER_INTERNAL);
56 }
Jason Sams732f1c02009-06-18 16:58:42 -070057 waitForCommand = false;
Jason Sams992a0b72009-06-23 12:22:47 -070058 //LOGV("playCoreCommands 3 %i %i", cmdID, cmdSize);
Jason Sams326e0dd2009-05-22 14:03:28 -070059
60 gPlaybackFuncs[cmdID](con, data);
Jason Sams326e0dd2009-05-22 14:03:28 -070061 mToCore.next();
Jason Sams326e0dd2009-05-22 14:03:28 -070062 }
Jason Samsa44cb292009-06-04 17:58:03 -070063 return ret;
Jason Sams326e0dd2009-05-22 14:03:28 -070064}
65
66