Skip to main content

ptx_parser/unparser/instruction/
wgmma_wait_group.rs

1//! Original PTX specification:
2//!
3//! wgmma.wait_group.sync.aligned N;
4
5#![allow(unused)]
6
7use crate::lexer::PtxToken;
8use crate::unparser::{PtxUnparser, common::*};
9
10pub mod section_0 {
11    use super::*;
12    use crate::r#type::instruction::wgmma_wait_group::section_0::*;
13
14    impl PtxUnparser for WgmmaWaitGroupSyncAligned {
15        fn unparse_tokens(&self, tokens: &mut ::std::vec::Vec<PtxToken>) {
16            self.unparse_tokens_mode(tokens, false);
17        }
18        fn unparse_tokens_mode(&self, tokens: &mut ::std::vec::Vec<PtxToken>, spaced: bool) {
19            push_opcode(tokens, "wgmma");
20            push_directive(tokens, "wait_group");
21            push_directive(tokens, "sync");
22            push_directive(tokens, "aligned");
23            if spaced {
24                tokens.push(PtxToken::Space);
25            }
26            self.n.unparse_tokens_mode(tokens, spaced);
27            tokens.push(PtxToken::Semicolon);
28            if spaced {
29                tokens.push(PtxToken::Newline);
30            }
31        }
32    }
33}