Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/Linux/drivers/gpu/drm/xe/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 7 kB image not shown  

Quelle  xe_tuning.c   Sprache: C

 
// SPDX-License-Identifier: MIT
/*
 * Copyright © 2022 Intel Corporation
 */


#include "xe_tuning.h"

#include <kunit/visibility.h>

#include <drm/drm_managed.h>

#include "regs/xe_gt_regs.h"
#include "xe_gt_types.h"
#include "xe_platform_types.h"
#include "xe_rtp.h"

#undef XE_REG_MCR
#define XE_REG_MCR(...)     XE_REG(__VA_ARGS__, .mcr = 1)

static const struct xe_rtp_entry_sr gt_tunings[] = {
 { XE_RTP_NAME("Tuning: Blend Fill Caching Optimization Disable"),
   XE_RTP_RULES(PLATFORM(DG2)),
   XE_RTP_ACTIONS(SET(XEHP_L3SCQREG7, BLEND_FILL_CACHING_OPT_DIS))
 },
 { XE_RTP_NAME("Tuning: 32B Access Enable"),
   XE_RTP_RULES(PLATFORM(DG2)),
   XE_RTP_ACTIONS(SET(XEHP_SQCM, EN_32B_ACCESS))
 },

 /* Xe2 */

 { XE_RTP_NAME("Tuning: L3 cache"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(2001, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(FIELD_SET(XEHP_L3SQCREG5, L3_PWM_TIMER_INIT_VAL_MASK,
       REG_FIELD_PREP(L3_PWM_TIMER_INIT_VAL_MASK, 0x7f)))
 },
 { XE_RTP_NAME("Tuning: L3 cache - media"),
   XE_RTP_RULES(MEDIA_VERSION_RANGE(2000, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(FIELD_SET(XE2LPM_L3SQCREG5, L3_PWM_TIMER_INIT_VAL_MASK,
       REG_FIELD_PREP(L3_PWM_TIMER_INIT_VAL_MASK, 0x7f)))
 },
 { XE_RTP_NAME("Tuning: Compression Overfetch"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(2001, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(CLR(CCCHKNREG1, ENCOMPPERFFIX),
    SET(CCCHKNREG1, L3CMPCTRL))
 },
 { XE_RTP_NAME("Tuning: Compression Overfetch - media"),
   XE_RTP_RULES(MEDIA_VERSION_RANGE(2000, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(CLR(XE2LPM_CCCHKNREG1, ENCOMPPERFFIX),
    SET(XE2LPM_CCCHKNREG1, L3CMPCTRL))
 },
 { XE_RTP_NAME("Tuning: Enable compressible partial write overfetch in L3"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(2001, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(SET(L3SQCREG3, COMPPWOVERFETCHEN))
 },
 { XE_RTP_NAME("Tuning: Enable compressible partial write overfetch in L3 - media"),
   XE_RTP_RULES(MEDIA_VERSION_RANGE(2000, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(SET(XE2LPM_L3SQCREG3, COMPPWOVERFETCHEN))
 },
 { XE_RTP_NAME("Tuning: L2 Overfetch Compressible Only"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(2001, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(SET(L3SQCREG2,
        COMPMEMRD256BOVRFETCHEN))
 },
 { XE_RTP_NAME("Tuning: L2 Overfetch Compressible Only - media"),
   XE_RTP_RULES(MEDIA_VERSION_RANGE(2000, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(SET(XE2LPM_L3SQCREG2,
        COMPMEMRD256BOVRFETCHEN))
 },
 { XE_RTP_NAME("Tuning: Stateless compression control"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(2001, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(FIELD_SET(STATELESS_COMPRESSION_CTRL, UNIFIED_COMPRESSION_FORMAT,
       REG_FIELD_PREP(UNIFIED_COMPRESSION_FORMAT, 0)))
 },
 { XE_RTP_NAME("Tuning: Stateless compression control - media"),
   XE_RTP_RULES(MEDIA_VERSION_RANGE(1301, XE_RTP_END_VERSION_UNDEFINED)),
   XE_RTP_ACTIONS(FIELD_SET(STATELESS_COMPRESSION_CTRL, UNIFIED_COMPRESSION_FORMAT,
       REG_FIELD_PREP(UNIFIED_COMPRESSION_FORMAT, 0)))
 },
 { XE_RTP_NAME("Tuning: L3 RW flush all Cache"),
   XE_RTP_RULES(GRAPHICS_VERSION(2004)),
   XE_RTP_ACTIONS(SET(SCRATCH3_LBCF, RWFLUSHALLEN))
 },
 { XE_RTP_NAME("Tuning: L3 RW flush all cache - media"),
   XE_RTP_RULES(MEDIA_VERSION(2000)),
   XE_RTP_ACTIONS(SET(XE2LPM_SCRATCH3_LBCF, RWFLUSHALLEN))
 },
};

static const struct xe_rtp_entry_sr engine_tunings[] = {
 { XE_RTP_NAME("Tuning: L3 Hashing Mask"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210),
         FUNC(xe_rtp_match_first_render_or_compute)),
   XE_RTP_ACTIONS(CLR(XELP_GARBCNTL, XELP_BUS_HASH_CTL_BIT_EXC))
 },
 { XE_RTP_NAME("Tuning: Set Indirect State Override"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1274),
         ENGINE_CLASS(RENDER)),
   XE_RTP_ACTIONS(SET(SAMPLER_MODE, INDIRECT_STATE_BASE_ADDR_OVERRIDE))
 },
 { XE_RTP_NAME("Tuning: Disable NULL query for Anyhit Shader"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(3000, XE_RTP_END_VERSION_UNDEFINED),
         FUNC(xe_rtp_match_first_render_or_compute)),
   XE_RTP_ACTIONS(SET(RT_CTRL, DIS_NULL_QUERY))
 },
};

static const struct xe_rtp_entry_sr lrc_tunings[] = {
 /* DG2 */

 { XE_RTP_NAME("Tuning: L3 cache"),
   XE_RTP_RULES(PLATFORM(DG2), ENGINE_CLASS(RENDER)),
   XE_RTP_ACTIONS(FIELD_SET(XEHP_L3SQCREG5, L3_PWM_TIMER_INIT_VAL_MASK,
       REG_FIELD_PREP(L3_PWM_TIMER_INIT_VAL_MASK, 0x7f)))
 },
 { XE_RTP_NAME("Tuning: TDS gang timer"),
   XE_RTP_RULES(PLATFORM(DG2), ENGINE_CLASS(RENDER)),
   /* read verification is ignored as in i915 - need to check enabling */
   XE_RTP_ACTIONS(FIELD_SET_NO_READ_MASK(XEHP_FF_MODE2,
      FF_MODE2_TDS_TIMER_MASK,
      FF_MODE2_TDS_TIMER_128))
 },
 { XE_RTP_NAME("Tuning: TBIMR fast clip"),
   XE_RTP_RULES(PLATFORM(DG2), ENGINE_CLASS(RENDER)),
   XE_RTP_ACTIONS(SET(CHICKEN_RASTER_2, TBIMR_FAST_CLIP))
 },

 /* Xe_LPG */

 { XE_RTP_NAME("Tuning: L3 cache"),
   XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1270, 1274), ENGINE_CLASS(RENDER)),
   XE_RTP_ACTIONS(FIELD_SET(XEHP_L3SQCREG5, L3_PWM_TIMER_INIT_VAL_MASK,
       REG_FIELD_PREP(L3_PWM_TIMER_INIT_VAL_MASK, 0x7f)))
 },

 /* Xe2_HPG */

 { XE_RTP_NAME("Tuning: vs hit max value"),
   XE_RTP_RULES(GRAPHICS_VERSION(2001), ENGINE_CLASS(RENDER)),
   XE_RTP_ACTIONS(FIELD_SET(FF_MODE, VS_HIT_MAX_VALUE_MASK,
       REG_FIELD_PREP(VS_HIT_MAX_VALUE_MASK, 0x3f)))
 },
};

/**
 * xe_tuning_init - initialize gt with tunings bookkeeping
 * @gt: GT instance to initialize
 *
 * Returns 0 for success, negative error code otherwise.
 */

int xe_tuning_init(struct xe_gt *gt)
{
 struct xe_device *xe = gt_to_xe(gt);
 size_t n_lrc, n_engine, n_gt, total;
 unsigned long *p;

 n_gt = BITS_TO_LONGS(ARRAY_SIZE(gt_tunings));
 n_engine = BITS_TO_LONGS(ARRAY_SIZE(engine_tunings));
 n_lrc = BITS_TO_LONGS(ARRAY_SIZE(lrc_tunings));
 total = n_gt + n_engine + n_lrc;

 p = drmm_kzalloc(&xe->drm, sizeof(*p) * total, GFP_KERNEL);
 if (!p)
  return -ENOMEM;

 gt->tuning_active.gt = p;
 p += n_gt;
 gt->tuning_active.engine = p;
 p += n_engine;
 gt->tuning_active.lrc = p;

 return 0;
}
ALLOW_ERROR_INJECTION(xe_tuning_init, ERRNO); /* See xe_pci_probe() */

void xe_tuning_process_gt(struct xe_gt *gt)
{
 struct xe_rtp_process_ctx ctx = XE_RTP_PROCESS_CTX_INITIALIZER(gt);

 xe_rtp_process_ctx_enable_active_tracking(&ctx,
        gt->tuning_active.gt,
        ARRAY_SIZE(gt_tunings));
 xe_rtp_process_to_sr(&ctx, gt_tunings, ARRAY_SIZE(gt_tunings), >->reg_sr);
}
EXPORT_SYMBOL_IF_KUNIT(xe_tuning_process_gt);

void xe_tuning_process_engine(struct xe_hw_engine *hwe)
{
 struct xe_rtp_process_ctx ctx = XE_RTP_PROCESS_CTX_INITIALIZER(hwe);

 xe_rtp_process_ctx_enable_active_tracking(&ctx,
        hwe->gt->tuning_active.engine,
        ARRAY_SIZE(engine_tunings));
 xe_rtp_process_to_sr(&ctx, engine_tunings, ARRAY_SIZE(engine_tunings),
        &hwe->reg_sr);
}
EXPORT_SYMBOL_IF_KUNIT(xe_tuning_process_engine);

/**
 * xe_tuning_process_lrc - process lrc tunings
 * @hwe: engine instance to process tunings for
 *
 * Process LRC table for this platform, saving in @hwe all the tunings that need
 * to be applied on context restore. These are tunings touching registers that
 * are part of the HW context image.
 */

void xe_tuning_process_lrc(struct xe_hw_engine *hwe)
{
 struct xe_rtp_process_ctx ctx = XE_RTP_PROCESS_CTX_INITIALIZER(hwe);

 xe_rtp_process_ctx_enable_active_tracking(&ctx,
        hwe->gt->tuning_active.lrc,
        ARRAY_SIZE(lrc_tunings));
 xe_rtp_process_to_sr(&ctx, lrc_tunings, ARRAY_SIZE(lrc_tunings), &hwe->reg_lrc);
}

void xe_tuning_dump(struct xe_gt *gt, struct drm_printer *p)
{
 size_t idx;

 drm_printf(p, "GT Tunings\n");
 for_each_set_bit(idx, gt->tuning_active.gt, ARRAY_SIZE(gt_tunings))
  drm_printf_indent(p, 1, "%s\n", gt_tunings[idx].name);

 drm_printf(p, "\nEngine Tunings\n");
 for_each_set_bit(idx, gt->tuning_active.engine, ARRAY_SIZE(engine_tunings))
  drm_printf_indent(p, 1, "%s\n", engine_tunings[idx].name);

 drm_printf(p, "\nLRC Tunings\n");
 for_each_set_bit(idx, gt->tuning_active.lrc, ARRAY_SIZE(lrc_tunings))
  drm_printf_indent(p, 1, "%s\n", lrc_tunings[idx].name);
}

Messung V0.5
C=94 H=95 G=94

¤ Dauer der Verarbeitung: 0.3 Sekunden  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.