Skip to main content

ptx_parser/unparser/instruction/
mad24.rs

1//! Original PTX specification:
2//!
3//! mad24.mode.type  d, a, b, c;
4//! mad24.hi.sat.s32 d, a, b, c;
5//! .mode = { .hi, .lo };
6//! .type = { .u32, .s32 };
7
8#![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}