Lines Matching full:scaler

131 	 * Once NV12 is enabled, handle it here while allocating scaler  in skl_update_scaler()
142 * if plane is being disabled or scaler is no more required or force detach in skl_update_scaler()
143 * - free scaler binded to this plane/crtc in skl_update_scaler()
146 * Here scaler state in crtc_state is set free so that in skl_update_scaler()
147 * scaler can be assigned to other user. Actual register in skl_update_scaler()
148 * update to free the scaler is done in plane/panel-fit programming. in skl_update_scaler()
158 "Staged freeing scaler id %d scaler_users = 0x%x\n", in skl_update_scaler()
207 "size is out of scaler range\n", in skl_update_scaler()
214 * The pipe scaler does not use all the bits of PIPESRC, at least in skl_update_scaler()
217 * we assume the limits match the scaler destination size limits. in skl_update_scaler()
224 "is out of scaler range\n", in skl_update_scaler()
229 /* mark this plane as a scaler user in crtc_state */ in skl_update_scaler()
261 * skl_update_scaler_plane - Stages update to scaler state for a given plane.
262 * @crtc_state: crtc's scaler state
278 /* Pre-gen11 and SDR planes always need a scaler for planar formats. */ in skl_update_scaler_plane()
326 "Cannot find scaler for %s:%d\n", name, idx)) in intel_atomic_setup_scaler()
329 /* set scaler mode */ in intel_atomic_setup_scaler()
339 * On gen11+'s HDR planes we only use the scaler for in intel_atomic_setup_scaler()
341 * we don't need the scaler to upsample the UV plane. in intel_atomic_setup_scaler()
357 * when only 1 scaler is in use on a pipe with 2 scalers in intel_atomic_setup_scaler()
358 * scaler 0 operates in high quality (HQ) mode. in intel_atomic_setup_scaler()
359 * In this case use scaler 0 to take advantage of HQ mode in intel_atomic_setup_scaler()
370 * FIXME: we should also check the scaler factors for pfit, so in intel_atomic_setup_scaler()
383 * as the first scaler, so we don't reject downscaling in intel_atomic_setup_scaler()
390 * scaler supports a vertical scaling factor in intel_atomic_setup_scaler()
411 * support HQ vs dynamic scaler properly. in intel_atomic_setup_scaler()
420 "Scaler %d doesn't support required plane scaling\n", in intel_atomic_setup_scaler()
429 drm_dbg_kms(display->drm, "Attached scaler id %u.%u to %s:%d\n", in intel_atomic_setup_scaler()
461 /* plane on different crtc cannot be a scaler user of this crtc */ in setup_plane_scaler()
494 * This function takes into account the current scaler(s) in use by any planes
516 * - staged scaler requests are already in scaler_state->scaler_users in intel_atomic_setup_scalers()
522 * - as part of crtc_commit, scaler will be either attached or detached in intel_atomic_setup_scalers()
538 /* skip if scaler not required */ in intel_atomic_setup_scalers()
600 * To enable nearest-neighbor scaling: program scaler coefficents with
723 const struct intel_scaler *scaler = in skl_program_plane_scaler() local
759 ps_ctrl = PS_SCALER_EN | PS_BINDING_PLANE(plane->id) | scaler->mode | in skl_program_plane_scaler()
819 /* find scaler attached to this pipe */ in skl_scaler_get_config()