/****************************************************************************** * * Copyright (C) 2015 The Android Open Source Project * * 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. * ***************************************************************************** * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore */ /** ******************************************************************************* * @file * ih264e_master.h * * @brief * Contains declarations of functions used by master thread * * @author * ittiam * * @remarks * None * ******************************************************************************* */ #ifndef IH264E_MASTER_H_ #define IH264E_MASTER_H_ /*****************************************************************************/ /* Extern Function Declarations */ /*****************************************************************************/ /** ****************************************************************************** * * @brief * This function joins all the spawned threads after successful completion of * their tasks * * @par Description * * @param[in] ps_codec * pointer to codec context * * @returns none * ****************************************************************************** */ void ih264e_join_threads(codec_t *ps_codec); /** ****************************************************************************** * * @brief This function puts the current thread to sleep for a duration * of sleep_us * * @par Description * ithread_yield() method causes the calling thread to yield execution to another * thread that is ready to run on the current processor. The operating system * selects the thread to yield to. ithread_usleep blocks the current thread for * the specified number of milliseconds. In other words, yield just says, * end my timeslice prematurely, look around for other threads to run. If there * is nothing better than me, continue. Sleep says I don't want to run for x * milliseconds. Even if no other thread wants to run, don't make me run. * * @param[in] sleep_us * thread sleep duration * * @returns error_status * ****************************************************************************** */ IH264E_ERROR_T ih264e_wait_for_thread(UWORD32 sleep_us); /** ****************************************************************************** * * @brief * Encodes in synchronous api mode * * @par Description * This routine processes input yuv, encodes it and outputs bitstream and recon * * @param[in] ps_codec_obj * Pointer to codec object at API level * * @param[in] pv_api_ip * Pointer to input argument structure * * @param[out] pv_api_op * Pointer to output argument structure * * @returns Status * ****************************************************************************** */ WORD32 ih264e_encode(iv_obj_t *ps_codec_obj, void *pv_api_ip, void *pv_api_op); /** ******************************************************************************* * * @brief update encoder configuration parameters * * @par Description: * updates encoder configuration parameters from the given config set. * Initialize/reinitialize codec parameters according to new configurations. * * @param[in] ps_codec * Pointer to codec context * * @param[in] ps_cfg * Pointer to config param set * * @remarks none * ******************************************************************************* */ IH264E_ERROR_T ih264e_codec_update_config(codec_t *ps_codec, cfg_params_t *ps_cfg); #endif /* IH264E_MASTER_H_ */