ptx_parser/unparser/instruction/
mad24.rs1#![allow(unused)]
9
10use crate::lexer::PtxToken;
11use crate::unparser::{PtxUnparser, common::*};
12
13pub mod section_0 {
14 use super::*;
15 use crate::r#type::instruction::mad24::section_0::*;
16
17 impl PtxUnparser for Mad24ModeType {
18 fn unparse_tokens(&self, tokens: &mut ::std::vec::Vec<PtxToken>) {
19 self.unparse_tokens_mode(tokens, false);
20 }
21 fn unparse_tokens_mode(&self, tokens: &mut ::std::vec::Vec<PtxToken>, spaced: bool) {
22 push_opcode(tokens, "mad24");
23 match &self.mode {
24 Mode::Hi => {
25 push_directive(tokens, "hi");
26 }
27 Mode::Lo => {
28 push_directive(tokens, "lo");
29 }
30 }
31 match &self.type_ {
32 Type::U32 => {
33 push_directive(tokens, "u32");
34 }
35 Type::S32 => {
36 push_directive(tokens, "s32");
37 }
38 }
39 if spaced {
40 tokens.push(PtxToken::Space);
41 }
42 self.d.unparse_tokens_mode(tokens, spaced);
43 tokens.push(PtxToken::Comma);
44 if spaced {
45 tokens.push(PtxToken::Space);
46 }
47 self.a.unparse_tokens_mode(tokens, spaced);
48 tokens.push(PtxToken::Comma);
49 if spaced {
50 tokens.push(PtxToken::Space);
51 }
52 self.b.unparse_tokens_mode(tokens, spaced);
53 tokens.push(PtxToken::Comma);
54 if spaced {
55 tokens.push(PtxToken::Space);
56 }
57 self.c.unparse_tokens_mode(tokens, spaced);
58 tokens.push(PtxToken::Semicolon);
59 if spaced {
60 tokens.push(PtxToken::Newline);
61 }
62 }
63 }
64
65 impl PtxUnparser for Mad24HiSatS32 {
66 fn unparse_tokens(&self, tokens: &mut ::std::vec::Vec<PtxToken>) {
67 self.unparse_tokens_mode(tokens, false);
68 }
69 fn unparse_tokens_mode(&self, tokens: &mut ::std::vec::Vec<PtxToken>, spaced: bool) {
70 push_opcode(tokens, "mad24");
71 push_directive(tokens, "hi");
72 push_directive(tokens, "sat");
73 push_directive(tokens, "s32");
74 if spaced {
75 tokens.push(PtxToken::Space);
76 }
77 self.d.unparse_tokens_mode(tokens, spaced);
78 tokens.push(PtxToken::Comma);
79 if spaced {
80 tokens.push(PtxToken::Space);
81 }
82 self.a.unparse_tokens_mode(tokens, spaced);
83 tokens.push(PtxToken::Comma);
84 if spaced {
85 tokens.push(PtxToken::Space);
86 }
87 self.b.unparse_tokens_mode(tokens, spaced);
88 tokens.push(PtxToken::Comma);
89 if spaced {
90 tokens.push(PtxToken::Space);
91 }
92 self.c.unparse_tokens_mode(tokens, spaced);
93 tokens.push(PtxToken::Semicolon);
94 if spaced {
95 tokens.push(PtxToken::Newline);
96 }
97 }
98 }
99}