Home | History | Annotate | Download | only in utils
      1 /*
      2 * Copyright (c) 2014 - 2017, The Linux Foundation. All rights reserved.
      3 *
      4 * Redistribution and use in source and binary forms, with or without modification, are permitted
      5 * provided that the following conditions are met:
      6 *    * Redistributions of source code must retain the above copyright notice, this list of
      7 *      conditions and the following disclaimer.
      8 *    * Redistributions in binary form must reproduce the above copyright notice, this list of
      9 *      conditions and the following disclaimer in the documentation and/or other materials provided
     10 *      with the distribution.
     11 *    * Neither the name of The Linux Foundation nor the names of its contributors may be used to
     12 *      endorse or promote products derived from this software without specific prior written
     13 *      permission.
     14 *
     15 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     16 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
     17 * NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
     18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
     19 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
     20 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     21 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
     22 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     23 */
     24 
     25 #ifndef __CONSTANTS_H__
     26 #define __CONSTANTS_H__
     27 
     28 #include <stdlib.h>
     29 #include <inttypes.h>
     30 
     31 #ifndef PRIu64
     32 #define PRIu64 "llu"
     33 #endif
     34 
     35 #define INT(exp) static_cast<int>(exp)
     36 #define FLOAT(exp) static_cast<float>(exp)
     37 #define UINT8(exp) static_cast<uint8_t>(exp)
     38 #define UINT16(exp) static_cast<uint16_t>(exp)
     39 #define UINT32(exp) static_cast<uint32_t>(exp)
     40 #define INT32(exp) static_cast<int32_t>(exp)
     41 #define UINT64(exp) static_cast<uint64_t>(exp)
     42 
     43 #define ROUND_UP(number, step) ((((number) + ((step) - 1)) / (step)) * (step))
     44 
     45 #define BITMAP(bit) (1 << (bit))
     46 
     47 #define ROUND_UP_ALIGN_DOWN(value, a) FLOAT(FloorToMultipleOf(UINT32(value + 0.5f), UINT32(a)))
     48 #define ROUND_UP_ALIGN_UP(value, a) FLOAT(CeilToMultipleOf(UINT32(value + 0.5f), UINT32(a)))
     49 
     50 #define IDLE_TIMEOUT_DEFAULT_MS 70
     51 #define IDLE_TIMEOUT_ACTIVE_MS IDLE_TIMEOUT_DEFAULT_MS
     52 #define IDLE_TIMEOUT_INACTIVE_MS 520
     53 
     54 #define IS_RGB_FORMAT(format) (((format) < kFormatYCbCr420Planar) ? true: false)
     55 
     56 #define BITS_PER_BYTE 8
     57 #define BITS_TO_BYTES(x) (((x) + (BITS_PER_BYTE - 1)) / (BITS_PER_BYTE))
     58 
     59 // factor value should be in powers of 2(eg: 1, 2, 4, 8)
     60 template <class T1, class T2>
     61 inline T1 FloorToMultipleOf(const T1 &value, const T2 &factor) {
     62   return (T1)(value & (~(factor - 1)));
     63 }
     64 
     65 template <class T1, class T2>
     66 inline T1 CeilToMultipleOf(const T1 &value, const T2 &factor) {
     67   return (T1)((value + (factor - 1)) & (~(factor - 1)));
     68 }
     69 
     70 namespace sdm {
     71 
     72   const int kThreadPriorityUrgent = -9;
     73   const int kMaxRotatePerLayer = 2;
     74   const uint32_t kMaxBlitTargetLayers = 2;
     75   const int kPageSize = 4096;
     76   const uint32_t kGridSize = 129;  // size used for non-linear transformation before Tone-mapping
     77   const uint32_t kLutDim = 17;  // Dim of the 3d LUT for tone-mapping.
     78 
     79   typedef void * Handle;
     80 
     81 }  // namespace sdm
     82 
     83 #endif  // __CONSTANTS_H__
     84 
     85