summaryrefslogtreecommitdiffstats
path: root/src/shader_recompiler/frontend/maxwell/translate/impl/video_helper.cpp
blob: e1f4174cf6ac6fa8460bfb9bea8a219280e21d0a (plain) (blame)
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
// Copyright 2021 yuzu Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.

#include "shader_recompiler/exception.h"
#include "shader_recompiler/frontend/maxwell/translate/impl/video_helper.h"

namespace Shader::Maxwell {

IR::U32 ExtractVideoOperandValue(IR::IREmitter& ir, const IR::U32& value, VideoWidth width,
                                 u32 selector, bool is_signed) {
    switch (width) {
    case VideoWidth::Byte:
    case VideoWidth::Unknown:
        return ir.BitFieldExtract(value, ir.Imm32(selector * 8), ir.Imm32(8), is_signed);
    case VideoWidth::Short:
        return ir.BitFieldExtract(value, ir.Imm32(selector * 16), ir.Imm32(16), is_signed);
    case VideoWidth::Word:
        return value;
    default:
        throw NotImplementedException("Unknown VideoWidth {}", width);
    }
}

VideoWidth GetVideoSourceWidth(VideoWidth width, bool is_immediate) {
    // immediates must be 16-bit format.
    return is_immediate ? VideoWidth::Short : width;
}

} // namespace Shader::Maxwell