1/* 2 * Copyright (C) 2011-2013 Intel Corporation 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a 5 * copy of this software and associated documentation files (the "Software"), 6 * to deal in the Software without restriction, including without limitation 7 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8 * and/or sell copies of the Software, and to permit persons to whom the 9 * Software is furnished to do so, subject to the following conditions: 10 * 11 * The above copyright notice and this permission notice (including the next 12 * paragraph) shall be included in all copies or substantial portions of the 13 * Software. 14 * 15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 * SOFTWARE. 22 */ 23 24#ifndef DRM_RECT_H 25#define DRM_RECT_H 26 27#include <linux/types.h> 28 29/** 30 * DOC: rect utils 31 * 32 * Utility functions to help manage rectangular areas for 33 * clipping, scaling, etc. calculations. 34 */ 35 36/** 37 * struct drm_rect - two dimensional rectangle 38 * @x1: horizontal starting coordinate (inclusive) 39 * @x2: horizontal ending coordinate (exclusive) 40 * @y1: vertical starting coordinate (inclusive) 41 * @y2: vertical ending coordinate (exclusive) 42 */ 43struct drm_rect { 44 int x1, y1, x2, y2; 45}; 46 47/** 48 * DRM_RECT_FMT - printf string for &struct drm_rect 49 */ 50#define DRM_RECT_FMT "%dx%d%+d%+d" 51/** 52 * DRM_RECT_ARG - printf arguments for &struct drm_rect 53 * @r: rectangle struct 54 */ 55#define DRM_RECT_ARG(r) drm_rect_width(r), drm_rect_height(r), (r)->x1, (r)->y1 56 57/** 58 * DRM_RECT_FP_FMT - printf string for &struct drm_rect in 16.16 fixed point 59 */ 60#define DRM_RECT_FP_FMT "%d.%06ux%d.%06u%+d.%06u%+d.%06u" 61/** 62 * DRM_RECT_FP_ARG - printf arguments for &struct drm_rect in 16.16 fixed point 63 * @r: rectangle struct 64 * 65 * This is useful for e.g. printing plane source rectangles, which are in 16.16 66 * fixed point. 67 */ 68#define DRM_RECT_FP_ARG(r) \ 69 drm_rect_width(r) >> 16, ((drm_rect_width(r) & 0xffff) * 15625) >> 10, \ 70 drm_rect_height(r) >> 16, ((drm_rect_height(r) & 0xffff) * 15625) >> 10, \ 71 (r)->x1 >> 16, (((r)->x1 & 0xffff) * 15625) >> 10, \ 72 (r)->y1 >> 16, (((r)->y1 & 0xffff) * 15625) >> 10 73 74/** 75 * drm_rect_init - initialize the rectangle from x/y/w/h 76 * @r: rectangle 77 * @x: x coordinate 78 * @y: y coordinate 79 * @width: width 80 * @height: height 81 */ 82static inline void drm_rect_init(struct drm_rect *r, int x, int y, 83 int width, int height) 84{ 85 r->x1 = x; 86 r->y1 = y; 87 r->x2 = x + width; 88 r->y2 = y + height; 89} 90 91/** 92 * drm_rect_adjust_size - adjust the size of the rectangle 93 * @r: rectangle to be adjusted 94 * @dw: horizontal adjustment 95 * @dh: vertical adjustment 96 * 97 * Change the size of rectangle @r by @dw in the horizontal direction, 98 * and by @dh in the vertical direction, while keeping the center 99 * of @r stationary. 100 * 101 * Positive @dw and @dh increase the size, negative values decrease it. 102 */ 103static inline void drm_rect_adjust_size(struct drm_rect *r, int dw, int dh) 104{ 105 r->x1 -= dw >> 1; 106 r->y1 -= dh >> 1; 107 r->x2 += (dw + 1) >> 1; 108 r->y2 += (dh + 1) >> 1; 109} 110 111/** 112 * drm_rect_translate - translate the rectangle 113 * @r: rectangle to be tranlated 114 * @dx: horizontal translation 115 * @dy: vertical translation 116 * 117 * Move rectangle @r by @dx in the horizontal direction, 118 * and by @dy in the vertical direction. 119 */ 120static inline void drm_rect_translate(struct drm_rect *r, int dx, int dy) 121{ 122 r->x1 += dx; 123 r->y1 += dy; 124 r->x2 += dx; 125 r->y2 += dy; 126} 127 128/** 129 * drm_rect_translate_to - translate the rectangle to an absolute position 130 * @r: rectangle to be tranlated 131 * @x: horizontal position 132 * @y: vertical position 133 * 134 * Move rectangle @r to @x in the horizontal direction, 135 * and to @y in the vertical direction. 136 */ 137static inline void drm_rect_translate_to(struct drm_rect *r, int x, int y) 138{ 139 drm_rect_translate(r, x - r->x1, y - r->y1); 140} 141 142/** 143 * drm_rect_downscale - downscale a rectangle 144 * @r: rectangle to be downscaled 145 * @horz: horizontal downscale factor 146 * @vert: vertical downscale factor 147 * 148 * Divide the coordinates of rectangle @r by @horz and @vert. 149 */ 150static inline void drm_rect_downscale(struct drm_rect *r, int horz, int vert) 151{ 152 r->x1 /= horz; 153 r->y1 /= vert; 154 r->x2 /= horz; 155 r->y2 /= vert; 156} 157 158/** 159 * drm_rect_width - determine the rectangle width 160 * @r: rectangle whose width is returned 161 * 162 * RETURNS: 163 * The width of the rectangle. 164 */ 165static inline int drm_rect_width(const struct drm_rect *r) 166{ 167 return r->x2 - r->x1; 168} 169 170/** 171 * drm_rect_height - determine the rectangle height 172 * @r: rectangle whose height is returned 173 * 174 * RETURNS: 175 * The height of the rectangle. 176 */ 177static inline int drm_rect_height(const struct drm_rect *r) 178{ 179 return r->y2 - r->y1; 180} 181 182/** 183 * drm_rect_visible - determine if the rectangle is visible 184 * @r: rectangle whose visibility is returned 185 * 186 * RETURNS: 187 * %true if the rectangle is visible, %false otherwise. 188 */ 189static inline bool drm_rect_visible(const struct drm_rect *r) 190{ 191 return drm_rect_width(r) > 0 && drm_rect_height(r) > 0; 192} 193 194/** 195 * drm_rect_equals - determine if two rectangles are equal 196 * @r1: first rectangle 197 * @r2: second rectangle 198 * 199 * RETURNS: 200 * %true if the rectangles are equal, %false otherwise. 201 */ 202static inline bool drm_rect_equals(const struct drm_rect *r1, 203 const struct drm_rect *r2) 204{ 205 return r1->x1 == r2->x1 && r1->x2 == r2->x2 && 206 r1->y1 == r2->y1 && r1->y2 == r2->y2; 207} 208 209bool drm_rect_intersect(struct drm_rect *r, const struct drm_rect *clip); 210bool drm_rect_clip_scaled(struct drm_rect *src, struct drm_rect *dst, 211 const struct drm_rect *clip); 212int drm_rect_calc_hscale(const struct drm_rect *src, 213 const struct drm_rect *dst, 214 int min_hscale, int max_hscale); 215int drm_rect_calc_vscale(const struct drm_rect *src, 216 const struct drm_rect *dst, 217 int min_vscale, int max_vscale); 218void drm_rect_debug_print(const char *prefix, 219 const struct drm_rect *r, bool fixed_point); 220void drm_rect_rotate(struct drm_rect *r, 221 int width, int height, 222 unsigned int rotation); 223void drm_rect_rotate_inv(struct drm_rect *r, 224 int width, int height, 225 unsigned int rotation); 226 227#endif 228