Lines Matching full:instance
26 * one specific instance). Reads of MCR registers always operate in a unicast
28 * Selection of a specific MCR instance for unicast operations is referred to
47 "INSTANCE 0",
199 * @instance: instance number (documented as "subsliceid" on older platforms)
209 int group, int instance, u32 value) in rw_with_mcr_steering_fw() argument
220 * to unicast mode when doing writes of a specific instance. in rw_with_mcr_steering_fw()
226 REG_FIELD_PREP(MTL_MCR_INSTANCEID, instance) | in rw_with_mcr_steering_fw()
230 mcr_ss = GEN11_MCR_SLICE(group) | GEN11_MCR_SUBSLICE(instance); in rw_with_mcr_steering_fw()
237 * from a single register instance regardless of how that bit in rw_with_mcr_steering_fw()
255 mcr_ss = GEN8_MCR_SLICE(group) | GEN8_MCR_SUBSLICE(instance); in rw_with_mcr_steering_fw()
286 int group, int instance, in rw_with_mcr_steering() argument
304 val = rw_with_mcr_steering_fw(gt, reg, rw_flag, group, instance, value); in rw_with_mcr_steering()
425 * intel_gt_mcr_read - read a specific instance of an MCR register
429 * @instance: the MCR instance
434 * group/instance.
438 int group, int instance) in intel_gt_mcr_read() argument
440 return rw_with_mcr_steering(gt, reg, FW_REG_READ, group, instance, 0); in intel_gt_mcr_read()
444 * intel_gt_mcr_unicast_write - write a specific instance of an MCR register
449 * @instance: the MCR instance
452 * group/instance.
457 int group, int instance) in intel_gt_mcr_unicast_write() argument
459 rw_with_mcr_steering(gt, reg, FW_REG_WRITE, group, instance, value); in intel_gt_mcr_unicast_write()
528 * instance and the write will be applied to all instances.
588 * @instance: Instance ID returned
590 * Determines group and instance values that will steer reads of the specified
591 * MCR class to a non-terminated instance.
595 u8 *group, u8 *instance) in get_nonterminated_steering() argument
602 *instance = __ffs(gt->info.l3bank_mask); in get_nonterminated_steering()
607 *instance = 0; /* unused */ in get_nonterminated_steering()
616 *instance = 0; /* unused */ in get_nonterminated_steering()
620 *instance = 0; in get_nonterminated_steering()
625 *instance = dss % GEN_DSS_PER_GSLICE; in get_nonterminated_steering()
629 * There are a lot of MCR types for which instance (0, 0) in get_nonterminated_steering()
633 *instance = 0; in get_nonterminated_steering()
640 *instance = 0; in get_nonterminated_steering()
645 *instance = 0; in get_nonterminated_steering()
650 * intel_gt_mcr_get_nonterminated_steering - find group/instance values that
651 * will steer a register to a non-terminated instance
655 * @instance: return variable for instance steering
657 * This function returns a group/instance pair that is guaranteed to work for
664 u8 *group, u8 *instance) in intel_gt_mcr_get_nonterminated_steering() argument
670 get_nonterminated_steering(gt, type, group, instance); in intel_gt_mcr_get_nonterminated_steering()
676 *instance = gt->default_steering.instanceid; in intel_gt_mcr_get_nonterminated_steering()
680 * intel_gt_mcr_read_any_fw - reads one instance of an MCR register
685 * instance (i.e., one that isn't fused off or powered down by power gating).
692 * Returns the value from a non-terminated instance of @reg.
697 u8 group, instance; in intel_gt_mcr_read_any_fw() local
703 get_nonterminated_steering(gt, type, &group, &instance); in intel_gt_mcr_read_any_fw()
706 group, instance, 0); in intel_gt_mcr_read_any_fw()
714 * intel_gt_mcr_read_any - reads one instance of an MCR register
719 * instance (i.e., one that isn't fused off or powered down by power gating).
723 * Returns the value from a non-terminated instance of @reg.
728 u8 group, instance; in intel_gt_mcr_read_any() local
732 get_nonterminated_steering(gt, type, &group, &instance); in intel_gt_mcr_read_any()
735 group, instance, 0); in intel_gt_mcr_read_any()
748 u8 group, instance; in report_steering_type() local
758 get_nonterminated_steering(gt, type, &group, &instance); in report_steering_type()
759 drm_printf(p, "%s steering: group=0x%x, instance=0x%x\n", in report_steering_type()
760 intel_steering_types[type], group, instance); in report_steering_type()
777 drm_printf(p, "Default steering: group=0x%x, instance=0x%x\n", in intel_gt_mcr_report_steering()
792 * intel_gt_mcr_get_ss_steering - returns the group/instance steering for a SS
796 * @instance: pointer to storage for steering instance ID
798 * Returns the steering IDs (via the @group and @instance parameters) that
802 unsigned int *group, unsigned int *instance) in intel_gt_mcr_get_ss_steering() argument
806 *instance = dss % GEN_DSS_PER_GSLICE; in intel_gt_mcr_get_ss_steering()
809 *instance = dss % GEN_MAX_SS_PER_HSW_SLICE; in intel_gt_mcr_get_ss_steering()
836 * instance.