1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
|
/*
* Copyright (C) 2019-2021 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include <cstdint>
namespace NEO {
struct MemoryFlags {
uint32_t readWrite : 1;
uint32_t writeOnly : 1;
uint32_t readOnly : 1;
uint32_t useHostPtr : 1;
uint32_t allocHostPtr : 1;
uint32_t copyHostPtr : 1;
uint32_t hostWriteOnly : 1;
uint32_t hostReadOnly : 1;
uint32_t hostNoAccess : 1;
uint32_t kernelReadAndWrite : 1;
uint32_t forceLinearStorage : 1;
uint32_t accessFlagsUnrestricted : 1;
uint32_t noAccess : 1;
uint32_t locallyUncachedResource : 1;
uint32_t locallyUncachedInSurfaceState : 1;
uint32_t allowUnrestrictedSize : 1;
uint32_t forceHostMemory : 1;
uint32_t shareable : 1;
uint32_t resource48Bit : 1;
uint32_t compressedHint : 1;
uint32_t uncompressedHint : 1;
};
struct MemoryAllocFlags {
uint32_t allocWriteCombined : 1;
uint32_t usmInitialPlacementCpu : 1;
uint32_t usmInitialPlacementGpu : 1;
};
} // namespace NEO
|