diff options
| author | Ville Syrjälä <ville.syrjala@linux.intel.com> | 2017-09-15 20:46:23 +0300 | 
|---|---|---|
| committer | Ville Syrjälä <ville.syrjala@linux.intel.com> | 2017-11-21 16:19:17 +0200 | 
| commit | aadde840f9d7666b8dfc34f3da6ec5f9111de51e (patch) | |
| tree | 5ebc56af2728aaeb1a1086998a447cb9786bc09d /tools | |
| parent | a297c9348b258435fef08e98d6a89cbed1d2386d (diff) | |
tools/intel_watermark: Dump WM_LINETIME on SKL+
Reviewed-by: Dhinakaran Pandiyan <dhinakaran.pandiyan@intel.com>
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Diffstat (limited to 'tools')
| -rw-r--r-- | tools/intel_watermark.c | 15 | 
1 files changed, 15 insertions, 0 deletions
| diff --git a/tools/intel_watermark.c b/tools/intel_watermark.c index 43f846f8..9953fe59 100644 --- a/tools/intel_watermark.c +++ b/tools/intel_watermark.c @@ -145,11 +145,14 @@ static void skl_wm_dump(void)  	uint32_t wm[num_levels][num_pipes][num_planes];  	uint32_t wm_trans[num_pipes][num_planes];  	uint32_t buf_cfg[num_pipes][num_planes]; +	uint32_t wm_linetime[num_pipes];  	char reg_name[20];  	intel_register_access_init(intel_get_pci_device(), 0, -1);  	for (pipe = 0; pipe < num_pipes; pipe++) { +		wm_linetime[pipe] = read_reg(0x45270 + pipe * 0x4); +  		for (plane = 0; plane < num_planes; plane++) {  			addr =  base_addr +  pipe * 0x1000 + plane * 0x100; @@ -162,6 +165,13 @@ static void skl_wm_dump(void)  		}  	} +	for (pipe = 0; pipe < num_pipes; pipe++) { +		snprintf(reg_name, sizeof(reg_name), "WM_LINETIME_%c", +			 pipe_name(pipe)); +		printf("%-18s 0x%08x\t", reg_name, wm_linetime[pipe]); +	} +	printf("\n\n"); +  	for (plane = 0; plane < num_planes; plane++) {  		for (level = 0; level < num_levels; level++) {  			for (pipe = 0; pipe < num_pipes; pipe++) { @@ -212,8 +222,13 @@ static void skl_wm_dump(void)  	for (pipe = 0; pipe < num_pipes; pipe++) {  		uint32_t start, end, size;  		uint32_t lines, blocks, enable; +		uint32_t linetime;  		printf("PIPE_%c\n", pipe_name(pipe)); + +		linetime = REG_DECODE1(wm_linetime[pipe], 0, 9); +		printf("LINETIME: %d (%.3f usec)\n", linetime, linetime* 0.125f); +  		printf("LEVEL   CURSOR   PLANE_1   PLANE_2   PLANE_3   PLANE_4\n");  		for (level = 0; level < num_levels; level++) {  			printf("%5d  ", level); | 
