Skip to main content

ptx_parser/type/instruction/
clz.rs

1//! Original PTX specification:
2//!
3//! clz.type  d, a;
4//! .type = { .b32, .b64 };
5
6#![allow(unused)]
7use crate::r#type::common::*;
8
9pub mod section_0 {
10    use crate::Spanned;
11    use crate::parser::Span;
12    use crate::r#type::common::*;
13
14    use serde::Serialize;
15
16    #[derive(Debug, Clone, PartialEq, Serialize)]
17    pub enum Type {
18        B32, // .b32
19        B64, // .b64
20    }
21
22    #[derive(Debug, Clone, PartialEq, Spanned, Serialize)]
23    pub struct ClzType {
24        pub type_: Type,       // .type
25        pub d: GeneralOperand, // d
26        pub a: GeneralOperand, // a
27        pub span: Span,
28    }
29}
30
31// Re-export types with section suffixes to avoid naming conflicts
32// e.g., Type0 for section_0::Type, Type1 for section_1::Type
33pub use section_0::ClzType;
34pub use section_0::Type as Type0;