When we want to use float point operation on Linux we need to use within special kernel protection (`kernel_fpu_{begin,end}()`.), otherwise the kernel can clobber userspace FPU register state. For detecting these issues we use a tool named objtool (with -Ffa flags) to highlight the FPU problems, all warnings can be summed up as follows: ./tools/objtool/objtool check -Ffa drivers/gpu/drm/amd/display/dc/dml/dml_common_defs.o [..] dc/dsc/rc_calc.o: warning: objtool: get_qp_set()+0x2f8: FPU instruction outside of kernel_fpu_{begin,end}() [..] dc/dsc/rc_calc.o: warning: objtool: dsc_roundf()+0x5: FPU instruction outside of kernel_fpu_{begin,end}() [..] dc/dsc/rc_calc.o: warning: objtool: dsc_ceil()+0x5: FPU instruction outside of kernel_fpu_{begin,end}() [..] dc/dsc/rc_calc.o: warning: objtool: get_ofs_set()+0x3eb: FPU instruction outside of kernel_fpu_{begin,end}() [..] dc/dsc/rc_calc.o: warning: objtool: calc_rc_params()+0x3c: FPU instruction outside of kernel_fpu_{begin,end}() [..] dc/dsc/dc_dsc.o: warning: objtool: get_dsc_bandwidth_range.isra.0()+0x8d: FPU instruction outside of kernel_fpu_{begin,end}() [..] dc/dsc/dc_dsc.o: warning: objtool: setup_dsc_config()+0x2ef: FPU instruction outside of kernel_fpu_{begin,end}() [..] dc/dsc/rc_calc_dpi.o: warning: objtool:copy_pps_fields()+0xbb: FPU instruction outside of kernel_fpu_{begin,end}() [..] dc/dsc/rc_calc_dpi.o: warning: objtool: dscc_compute_dsc_parameters()+0x7b: FPU instruction outside of kernel_fpu_{begin,end}() This commit fixes the above issues by rework DSC as described: 1. Isolate all FPU operations in a single file; 2. Use FPU flags only in the file that handles FPU operations; 3. Isolate all functions that require float point operation in static functions; 4. Add a mid-layer function that does not use any float point operation, and that could be safely invoked in other parts of the code. 5. Keep float point operation under DC_FP_{START/END} macro. CC: Christian König <christian.koenig@amd.com> CC: Alexander Deucher <Alexander.Deucher@amd.com> CC: Peter Zijlstra <peterz@infradead.org> CC: Tony Cheng <tony.cheng@amd.com> CC: Harry Wentland <hwentlan@amd.com> Signed-off-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com> Reviewed-by: Mikita Lipski <Mikita.Lipski@amd.com> Acked-by: Qingqing Zhuo <qingqing.zhuo@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
87 lines
2.3 KiB
C
87 lines
2.3 KiB
C
|
|
/*
|
|
* Copyright 2017 Advanced Micro Devices, Inc.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
* to deal in the Software without restriction, including without limitation
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
|
* OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
* Authors: AMD
|
|
*
|
|
*/
|
|
|
|
#ifndef __RC_CALC_H__
|
|
#define __RC_CALC_H__
|
|
|
|
|
|
#define QP_SET_SIZE 15
|
|
|
|
typedef int qp_set[QP_SET_SIZE];
|
|
|
|
struct rc_params {
|
|
int rc_quant_incr_limit0;
|
|
int rc_quant_incr_limit1;
|
|
int initial_fullness_offset;
|
|
int initial_xmit_delay;
|
|
int first_line_bpg_offset;
|
|
int second_line_bpg_offset;
|
|
int flatness_min_qp;
|
|
int flatness_max_qp;
|
|
int flatness_det_thresh;
|
|
qp_set qp_min;
|
|
qp_set qp_max;
|
|
qp_set ofs;
|
|
int rc_model_size;
|
|
int rc_edge_factor;
|
|
int rc_tgt_offset_hi;
|
|
int rc_tgt_offset_lo;
|
|
int rc_buf_thresh[QP_SET_SIZE - 1];
|
|
};
|
|
|
|
enum colour_mode {
|
|
CM_RGB, /* 444 RGB */
|
|
CM_444, /* 444 YUV or simple 422 */
|
|
CM_422, /* native 422 */
|
|
CM_420 /* native 420 */
|
|
};
|
|
|
|
enum bits_per_comp {
|
|
BPC_8 = 8,
|
|
BPC_10 = 10,
|
|
BPC_12 = 12
|
|
};
|
|
|
|
enum max_min {
|
|
MM_MIN = 0,
|
|
MM_MAX = 1
|
|
};
|
|
|
|
struct qp_entry {
|
|
float bpp;
|
|
const qp_set qps;
|
|
};
|
|
|
|
typedef struct qp_entry qp_table[];
|
|
|
|
void calc_rc_params(struct rc_params *rc, const struct drm_dsc_config *pps);
|
|
u32 calc_dsc_bytes_per_pixel(const struct drm_dsc_config *pps);
|
|
u32 calc_dsc_bpp_x16(u32 stream_bandwidth_kbps, u32 pix_clk_100hz,
|
|
u32 bpp_increment_div);
|
|
|
|
#endif
|
|
|