if (write_pos > read_pos) {
                available = write_pos - read_pos;
-               read_num[0] = min(size, (size_t)available);
+               read_num[0] = min_t(size_t, size, available);
        } else {
                read_num[0] = AMDGPU_VCNFW_LOG_SIZE - read_pos;
                available = read_num[0] + write_pos - plog->header_size;
 
        if (amdgpu_vm_block_size != -1)
                tmp >>= amdgpu_vm_block_size - 9;
        tmp = DIV_ROUND_UP(fls64(tmp) - 1, 9) - 1;
-       adev->vm_manager.num_level = min(max_level, (unsigned)tmp);
+       adev->vm_manager.num_level = min_t(unsigned int, max_level, tmp);
        switch (adev->vm_manager.num_level) {
        case 3:
                adev->vm_manager.root_level = AMDGPU_VM_PDB2;
 
                                            (u32)mode->clock);
                line_time = (u32) div_u64((u64)mode->crtc_htotal * 1000000,
                                          (u32)mode->clock);
-               line_time = min(line_time, (u32)65535);
+               line_time = min_t(u32, line_time, 65535);
 
                /* watermark for high clocks */
                if (adev->pm.dpm_enabled) {
                wm_high.num_heads = num_heads;
 
                /* set for high clocks */
-               latency_watermark_a = min(dce_v10_0_latency_watermark(&wm_high), (u32)65535);
+               latency_watermark_a = min_t(u32, dce_v10_0_latency_watermark(&wm_high), 65535);
 
                /* possibly force display priority to high */
                /* should really do this at mode validation time... */
                wm_low.num_heads = num_heads;
 
                /* set for low clocks */
-               latency_watermark_b = min(dce_v10_0_latency_watermark(&wm_low), (u32)65535);
+               latency_watermark_b = min_t(u32, dce_v10_0_latency_watermark(&wm_low), 65535);
 
                /* possibly force display priority to high */
                /* should really do this at mode validation time... */
 
                                            (u32)mode->clock);
                line_time = (u32) div_u64((u64)mode->crtc_htotal * 1000000,
                                          (u32)mode->clock);
-               line_time = min(line_time, (u32)65535);
+               line_time = min_t(u32, line_time, 65535);
 
                /* watermark for high clocks */
                if (adev->pm.dpm_enabled) {
                wm_high.num_heads = num_heads;
 
                /* set for high clocks */
-               latency_watermark_a = min(dce_v11_0_latency_watermark(&wm_high), (u32)65535);
+               latency_watermark_a = min_t(u32, dce_v11_0_latency_watermark(&wm_high), 65535);
 
                /* possibly force display priority to high */
                /* should really do this at mode validation time... */
                wm_low.num_heads = num_heads;
 
                /* set for low clocks */
-               latency_watermark_b = min(dce_v11_0_latency_watermark(&wm_low), (u32)65535);
+               latency_watermark_b = min_t(u32, dce_v11_0_latency_watermark(&wm_low), 65535);
 
                /* possibly force display priority to high */
                /* should really do this at mode validation time... */
 
                                            (u32)mode->clock);
                line_time = (u32) div_u64((u64)mode->crtc_htotal * 1000000,
                                          (u32)mode->clock);
-               line_time = min(line_time, (u32)65535);
+               line_time = min_t(u32, line_time, 65535);
                priority_a_cnt = 0;
                priority_b_cnt = 0;
 
                wm_low.num_heads = num_heads;
 
                /* set for high clocks */
-               latency_watermark_a = min(dce_v6_0_latency_watermark(&wm_high), (u32)65535);
+               latency_watermark_a = min_t(u32, dce_v6_0_latency_watermark(&wm_high), 65535);
                /* set for low clocks */
-               latency_watermark_b = min(dce_v6_0_latency_watermark(&wm_low), (u32)65535);
+               latency_watermark_b = min_t(u32, dce_v6_0_latency_watermark(&wm_low), 65535);
 
                /* possibly force display priority to high */
                /* should really do this at mode validation time... */
 
                                            (u32)mode->clock);
                line_time = (u32) div_u64((u64)mode->crtc_htotal * 1000000,
                                          (u32)mode->clock);
-               line_time = min(line_time, (u32)65535);
+               line_time = min_t(u32, line_time, 65535);
 
                /* watermark for high clocks */
                if (adev->pm.dpm_enabled) {
                wm_high.num_heads = num_heads;
 
                /* set for high clocks */
-               latency_watermark_a = min(dce_v8_0_latency_watermark(&wm_high), (u32)65535);
+               latency_watermark_a = min_t(u32, dce_v8_0_latency_watermark(&wm_high), 65535);
 
                /* possibly force display priority to high */
                /* should really do this at mode validation time... */
                wm_low.num_heads = num_heads;
 
                /* set for low clocks */
-               latency_watermark_b = min(dce_v8_0_latency_watermark(&wm_low), (u32)65535);
+               latency_watermark_b = min_t(u32, dce_v8_0_latency_watermark(&wm_low), 65535);
 
                /* possibly force display priority to high */
                /* should really do this at mode validation time... */