| /* |
| * cl_multi_image_handler.cpp - CL multi-image handler |
| * |
| * Copyright (c) 2016 Intel Corporation |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| * |
| * Author: Wind Yuan <[email protected]> |
| */ |
| |
| #include "cl_multi_image_handler.h" |
| #if ENABLE_PROFILING |
| #include "cl_device.h" |
| #endif |
| |
| namespace XCam { |
| |
| CLMultiImageHandler::CLMultiImageHandler (const SmartPtr<CLContext> &context, const char *name) |
| : CLImageHandler (context, name) |
| { |
| } |
| |
| CLMultiImageHandler::~CLMultiImageHandler () |
| { |
| _handler_list.clear (); |
| } |
| |
| bool |
| CLMultiImageHandler::add_image_handler (SmartPtr<CLImageHandler> &handler) |
| { |
| _handler_list.push_back (handler); |
| return append_kernels (handler); |
| } |
| |
| XCamReturn |
| CLMultiImageHandler::execute_kernels () |
| { |
| XCamReturn ret = XCAM_RETURN_NO_ERROR; |
| |
| for (KernelList::iterator i_kernel = _kernels.begin (); |
| i_kernel != _kernels.end (); ++i_kernel) { |
| SmartPtr<CLImageKernel> &kernel = *i_kernel; |
| XCAM_FAIL_RETURN (WARNING, kernel.ptr(), ret, "kernel empty"); |
| |
| if (!kernel->is_enabled ()) |
| continue; |
| |
| ret = execute_kernel (kernel); |
| |
| XCAM_FAIL_RETURN ( |
| WARNING, |
| (ret == XCAM_RETURN_NO_ERROR || ret == XCAM_RETURN_BYPASS), ret, |
| "cl_multi_image_handler(%s) execute kernel(%s) failed", |
| XCAM_STR (_name), kernel->get_kernel_name ()); |
| |
| if (ret != XCAM_RETURN_NO_ERROR) |
| break; |
| |
| for (HandlerList::iterator i_handler = _handler_list.begin (); |
| i_handler != _handler_list.end (); ++i_handler) { |
| SmartPtr<CLImageHandler> &sub_handler = *i_handler; |
| XCAM_ASSERT (sub_handler.ptr ()); |
| |
| SmartPtr<CLImageKernel> &sub_handler_last_kernel = *(sub_handler->_kernels.rbegin()); |
| XCAM_ASSERT (sub_handler_last_kernel.ptr ()); |
| if (sub_handler_last_kernel.ptr () == kernel.ptr ()) { |
| sub_handler->reset_buf_cache (NULL, NULL); |
| sub_handler_execute_done (sub_handler); |
| break; |
| } |
| } |
| } |
| |
| return ret; |
| } |
| |
| XCamReturn |
| CLMultiImageHandler::ensure_handler_parameters ( |
| const SmartPtr<CLImageHandler> &handler, SmartPtr<VideoBuffer> &input, SmartPtr<VideoBuffer> &output) |
| { |
| XCAM_ASSERT (handler.ptr ()); |
| return handler->ensure_parameters (input, output); |
| } |
| |
| XCamReturn |
| CLMultiImageHandler::prepare_parameters (SmartPtr<VideoBuffer> &input, SmartPtr<VideoBuffer> &output) |
| { |
| for (HandlerList::iterator i_handler = _handler_list.begin (); |
| i_handler != _handler_list.end (); ++i_handler) { |
| SmartPtr<CLImageHandler> &handler = *i_handler; |
| XCAM_ASSERT (handler.ptr ()); |
| XCamReturn ret = ensure_handler_parameters (handler, input, output); |
| |
| XCAM_FAIL_RETURN ( |
| WARNING, |
| ret == XCAM_RETURN_NO_ERROR, |
| ret, |
| "CLMultiImageHandler(%s) prepare parameters failed on handler(%s)", |
| XCAM_STR (get_name ()), XCAM_STR (handler->get_name ())); |
| } |
| return XCAM_RETURN_NO_ERROR; |
| } |
| |
| XCamReturn |
| CLMultiImageHandler::execute_done (SmartPtr<VideoBuffer> &output) |
| { |
| for (HandlerList::iterator i_handler = _handler_list.begin (); |
| i_handler != _handler_list.end (); ++i_handler) { |
| SmartPtr<CLImageHandler> &handler = *i_handler; |
| XCAM_ASSERT (handler.ptr ()); |
| |
| XCamReturn ret = handler->execute_done (output); |
| if (ret == XCAM_RETURN_BYPASS) |
| return ret; |
| |
| XCAM_FAIL_RETURN ( |
| WARNING, |
| ret == XCAM_RETURN_NO_ERROR, |
| ret, |
| "CLMultiImageHandler(%s) execute buffer done failed on handler(%s)", |
| XCAM_STR (get_name ()), XCAM_STR (handler->get_name ())); |
| } |
| return XCAM_RETURN_NO_ERROR; |
| } |
| |
| XCamReturn |
| CLMultiImageHandler::sub_handler_execute_done (SmartPtr<CLImageHandler> &handler) |
| { |
| XCAM_UNUSED (handler); |
| return XCAM_RETURN_NO_ERROR; |
| } |
| |
| } |
| |