1 /****************************************************************************** 2 * 3 * Copyright (C) 2015 The Android Open Source Project 4 * 5 * Licensed under the Apache License, Version 2.0 (the "License"); 6 * you may not use this file except in compliance with the License. 7 * You may obtain a copy of the License at: 8 * 9 * http://www.apache.org/licenses/LICENSE-2.0 10 * 11 * Unless required by applicable law or agreed to in writing, software 12 * distributed under the License is distributed on an "AS IS" BASIS, 13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 * See the License for the specific language governing permissions and 15 * limitations under the License. 16 * 17 ***************************************************************************** 18 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore 19 */ 20 /** 21 ******************************************************************************* 22 * @file 23 * ih264e_platform_macros.h 24 * 25 * @brief 26 * Contains platform specific routines used for codec context intialization 27 * 28 * @author 29 * ittiam 30 * 31 * @remarks 32 * none 33 * 34 ******************************************************************************* 35 */ 36 37 38 #ifndef IH264E_PLATFORM_MACROS_H_ 39 #define IH264E_PLATFORM_MACROS_H_ 40 41 /*****************************************************************************/ 42 /* Extern Function Declarations */ 43 /*****************************************************************************/ 44 45 /** 46 ******************************************************************************* 47 * 48 * @brief Initialize the intra/inter/transform/deblk function pointers of 49 * codec context 50 * 51 * @par Description: the current routine initializes the function pointers of 52 * codec context basing on the architecture in use 53 * 54 * @param[in] ps_codec 55 * Codec context pointer 56 * 57 * @returns none 58 * 59 * @remarks none 60 * 61 ******************************************************************************* 62 */ 63 void ih264e_init_function_ptr_generic(codec_t *ps_codec); 64 /** 65 ******************************************************************************* 66 * 67 * @brief Initialize the intra/inter/transform/deblk function pointers of 68 * codec context 69 * 70 * @par Description: the current routine initializes the function pointers of 71 * codec context basing on the architecture in use 72 * 73 * @param[in] ps_codec 74 * Codec context pointer 75 * 76 * @returns none 77 * 78 * @remarks none 79 * 80 ******************************************************************************* 81 */ 82 void ih264e_init_function_ptr_ssse3(codec_t *ps_codec); 83 void ih264e_init_function_ptr_sse42(codec_t *ps_codec); 84 85 /** 86 ******************************************************************************* 87 * 88 * @brief Initialize the intra/inter/transform/deblk function pointers of 89 * codec context 90 * 91 * @par Description: the current routine initializes the function pointers of 92 * codec context basing on the architecture in use 93 * 94 * @param[in] ps_codec 95 * Codec context pointer 96 * 97 * @returns none 98 * 99 * @remarks none 100 * 101 ******************************************************************************* 102 */ 103 void ih264e_init_function_ptr(void *pv_codec); 104 105 /** 106 ******************************************************************************* 107 * 108 * @brief Determine the architecture of the encoder executing environment 109 * 110 * @par Description: This routine returns the architecture of the enviro- 111 * ment in which the current encoder is being tested 112 * 113 * @param[in] void 114 * 115 * @returns IV_ARCH_T 116 * architecture 117 * 118 * @remarks none 119 * 120 ******************************************************************************* 121 */ 122 IV_ARCH_T ih264e_default_arch(void); 123 124 /** 125 ******************************************************************************* 126 * 127 * @brief Data Memory Barrier, Data Synchronization Barrier 128 * 129 * 130 * @par Description: These functions do nothing on x86 side. But on arm platforms, 131 * 132 * Data Memory Barrier acts as a memory barrier. It ensures that all explicit 133 * memory accesses that appear in program order before the DMB instruction are 134 * observed before any explicit memory accesses that appear in program order 135 * after the DMB instruction. It does not affect the ordering of any other 136 * instructions executing on the processor 137 * 138 * Data Synchronization Barrier acts as a special kind of memory barrier. No 139 * instruction in program order after this instruction executes until this instruction 140 * completes. This instruction completes when: 141 * 1. All explicit memory accesses before this instruction complete. 142 * 2. All Cache, Branch predictor and TLB maintenance operations before 143 * this instruction complete. 144 * 145 * @param[in] void 146 * 147 * @returns void 148 * 149 * @remarks none 150 * 151 ******************************************************************************* 152 */ 153 154 #endif /* IH264E_PLATFORM_MACROS_H_ */ 155