1 1.1 riastrad /* $NetBSD: intel_mocs.h,v 1.2 2021/12/18 23:45:30 riastradh Exp $ */ 2 1.1 riastrad 3 1.1 riastrad /* 4 1.1 riastrad * Copyright (c) 2015 Intel Corporation 5 1.1 riastrad * 6 1.1 riastrad * Permission is hereby granted, free of charge, to any person obtaining a 7 1.1 riastrad * copy of this software and associated documentation files (the "Software"), 8 1.1 riastrad * to deal in the Software without restriction, including without limitation 9 1.1 riastrad * the rights to use, copy, modify, merge, publish, distribute, sublicense, 10 1.1 riastrad * and/or sell copies of the Software, and to permit persons to whom the 11 1.1 riastrad * Software is furnished to do so, subject to the following conditions: 12 1.1 riastrad * 13 1.1 riastrad * The above copyright notice and this permission notice (including the next 14 1.1 riastrad * paragraph) shall be included in all copies or substantial portions of the 15 1.1 riastrad * Software. 16 1.1 riastrad * 17 1.1 riastrad * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 18 1.1 riastrad * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 19 1.1 riastrad * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 20 1.1 riastrad * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 21 1.1 riastrad * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 22 1.1 riastrad * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 23 1.1 riastrad * SOFTWARE. 24 1.1 riastrad */ 25 1.1 riastrad 26 1.1 riastrad #ifndef INTEL_MOCS_H 27 1.1 riastrad #define INTEL_MOCS_H 28 1.1 riastrad 29 1.1 riastrad /** 30 1.1 riastrad * DOC: Memory Objects Control State (MOCS) 31 1.1 riastrad * 32 1.1 riastrad * Motivation: 33 1.1 riastrad * In previous Gens the MOCS settings was a value that was set by user land as 34 1.1 riastrad * part of the batch. In Gen9 this has changed to be a single table (per ring) 35 1.1 riastrad * that all batches now reference by index instead of programming the MOCS 36 1.1 riastrad * directly. 37 1.1 riastrad * 38 1.1 riastrad * The one wrinkle in this is that only PART of the MOCS tables are included 39 1.1 riastrad * in context (The GFX_MOCS_0 - GFX_MOCS_64 and the LNCFCMOCS0 - LNCFCMOCS32 40 1.1 riastrad * registers). The rest are not (the settings for the other rings). 41 1.1 riastrad * 42 1.1 riastrad * This table needs to be set at system start-up because the way the table 43 1.1 riastrad * interacts with the contexts and the GmmLib interface. 44 1.1 riastrad * 45 1.1 riastrad * 46 1.1 riastrad * Implementation: 47 1.1 riastrad * 48 1.1 riastrad * The tables (one per supported platform) are defined in intel_mocs.c 49 1.1 riastrad * and are programmed in the first batch after the context is loaded 50 1.1 riastrad * (with the hardware workarounds). This will then let the usual 51 1.1 riastrad * context handling keep the MOCS in step. 52 1.1 riastrad */ 53 1.1 riastrad 54 1.1 riastrad struct intel_engine_cs; 55 1.1 riastrad struct intel_gt; 56 1.1 riastrad 57 1.1 riastrad void intel_mocs_init(struct intel_gt *gt); 58 1.1 riastrad void intel_mocs_init_engine(struct intel_engine_cs *engine); 59 1.1 riastrad 60 1.1 riastrad #endif 61