]> git.lizzy.rs Git - rust.git/commitdiff
rustc: Improve compile time of platform intrinsics
authorAlex Crichton <alex@alexcrichton.com>
Sun, 13 Mar 2016 22:01:37 +0000 (15:01 -0700)
committerAlex Crichton <alex@alexcrichton.com>
Wed, 16 Mar 2016 00:32:34 +0000 (17:32 -0700)
This commit improves the compile time of `rustc_platform_intrinsics` from 23s to
3.6s if compiling with `-O` and from 77s to 17s if compiling with `-O -g`. The
compiled rlib size also drops from 3.1M to 1.2M.

The wins here were gained by removing the destructors associated with `Type` by
removing the internal `Box` and `Vec` indirections. These destructors meant that
a lot of landing pads and extra code were generated to manage the runtime
representations. Instead everything can basically be statically computed and
shoved into rodata, so all we need is a giant string compare to lookup what's
what.

Closes #28273

src/etc/platform-intrinsics/generator.py
src/librustc_platform_intrinsics/aarch64.rs
src/librustc_platform_intrinsics/arm.rs
src/librustc_platform_intrinsics/lib.rs
src/librustc_platform_intrinsics/x86.rs
src/librustc_trans/trans/intrinsic.rs

index 0e0d4841063a4ac43c837dbb856379df98eb5931..786cb20ed75d5de00cc199ce6585983a453ce2c7 100644 (file)
@@ -117,7 +117,10 @@ class Void(Type):
         Type.__init__(self, 0)
 
     def compiler_ctor(self):
-        return 'void()'
+        return '::VOID'
+
+    def compiler_ctor_ref(self):
+        return '&' + self.compiler_ctor()
 
     def rust_name(self):
         return '()'
@@ -163,10 +166,12 @@ class Signed(Number):
 
     def compiler_ctor(self):
         if self._llvm_bitwidth is None:
-            return 'i({})'.format(self.bitwidth())
+            return '::I{}'.format(self.bitwidth())
         else:
-            return 'i_({}, {})'.format(self.bitwidth(),
-                                       self._llvm_bitwidth)
+            return '::I{}_{}'.format(self.bitwidth(), self._llvm_bitwidth)
+
+    def compiler_ctor_ref(self):
+        return '&' + self.compiler_ctor()
 
     def llvm_name(self):
         bw = self._llvm_bitwidth or self.bitwidth()
@@ -182,10 +187,12 @@ class Unsigned(Number):
 
     def compiler_ctor(self):
         if self._llvm_bitwidth is None:
-            return 'u({})'.format(self.bitwidth())
+            return '::U{}'.format(self.bitwidth())
         else:
-            return 'u_({}, {})'.format(self.bitwidth(),
-                                       self._llvm_bitwidth)
+            return '::U{}_{}'.format(self.bitwidth(), self._llvm_bitwidth)
+
+    def compiler_ctor_ref(self):
+        return '&' + self.compiler_ctor()
 
     def llvm_name(self):
         bw = self._llvm_bitwidth or self.bitwidth()
@@ -200,7 +207,10 @@ class Float(Number):
         Number.__init__(self, bitwidth)
 
     def compiler_ctor(self):
-        return 'f({})'.format(self.bitwidth())
+        return '::F{}'.format(self.bitwidth())
+
+    def compiler_ctor_ref(self):
+        return '&' + self.compiler_ctor()
 
     def llvm_name(self):
         return 'f{}'.format(self.bitwidth())
@@ -244,12 +254,16 @@ class Vector(Type):
 
     def compiler_ctor(self):
         if self._bitcast is None:
-            return 'v({}, {})'.format(self._elem.compiler_ctor(),
-                                      self._length)
+            return '{}x{}'.format(self._elem.compiler_ctor(),
+                                     self._length)
         else:
-            return 'v_({}, {}, {})'.format(self._elem.compiler_ctor(),
-                                           self._bitcast.compiler_ctor(),
-                                           self._length)
+            return '{}x{}_{}'.format(self._elem.compiler_ctor(),
+                                     self._length,
+                                     self._bitcast.compiler_ctor()
+                                         .replace('::', ''))
+
+    def compiler_ctor_ref(self):
+        return '&' + self.compiler_ctor()
 
     def rust_name(self):
         return '{}x{}'.format(self._elem.rust_name(), self._length)
@@ -284,10 +298,14 @@ class Pointer(Type):
         if self._llvm_elem is None:
             llvm_elem = 'None'
         else:
-            llvm_elem = 'Some({})'.format(self._llvm_elem.compiler_ctor())
-        return 'p({}, {}, {})'.format('true' if self._const else 'false',
-                                      self._elem.compiler_ctor(),
-                                      llvm_elem)
+            llvm_elem = 'Some({})'.format(self._llvm_elem.compiler_ctor_ref())
+        return 'Type::Pointer({}, {}, {})'.format(self._elem.compiler_ctor_ref(),
+                                                  llvm_elem,
+                                                  'true' if self._const else 'false')
+
+    def compiler_ctor_ref(self):
+        return "{{ static PTR: Type = {}; &PTR }}".format(self.compiler_ctor())
+
 
     def rust_name(self):
         return '*{} {}'.format('const' if self._const else 'mut',
@@ -322,8 +340,14 @@ class Aggregate(Type):
             raise NotImplementedError()
 
     def compiler_ctor(self):
-        return 'agg({}, vec![{}])'.format('true' if self._flatten else 'false',
-                                          ', '.join(elem.compiler_ctor() for elem in self._elems))
+        parts = "{{ static PARTS: [&'static Type; {}] = [{}]; &PARTS }}"
+        elems = ', '.join(elem.compiler_ctor_ref() for elem in self._elems)
+        parts = parts.format(len(self._elems), elems)
+        return 'Type::Aggregate({}, {})'.format('true' if self._flatten else 'false',
+                                                parts)
+
+    def compiler_ctor_ref(self):
+        return "{{ static AGG: Type = {}; &AGG }}".format(self.compiler_ctor())
 
     def rust_name(self):
         return '({})'.format(', '.join(elem.rust_name() for elem in self._elems))
@@ -518,10 +542,10 @@ class MonomorphicIntrinsic(object):
         return self._platform.platform().intrinsic_prefix() + self.intrinsic_suffix()
 
     def compiler_args(self):
-        return ', '.join(arg.compiler_ctor() for arg in self._args_raw)
+        return ', '.join(arg.compiler_ctor_ref() for arg in self._args_raw)
 
     def compiler_ret(self):
-        return self._ret_raw.compiler_ctor()
+        return self._ret_raw.compiler_ctor_ref()
 
     def compiler_signature(self):
         return '({}) -> {}'.format(self.compiler_args(), self.compiler_ret())
@@ -733,7 +757,7 @@ class CompilerDefs(object):
 
 #![allow(unused_imports)]
 
-use {{Intrinsic, i, i_, u, u_, f, v, v_, agg, p, void}};
+use {{Intrinsic, Type}};
 use IntrinsicDef::Named;
 use rustc::middle::ty::TyCtxt;
 
@@ -747,10 +771,11 @@ pub fn find<'tcx>(_tcx: &TyCtxt<'tcx>, name: &str) -> Option<Intrinsic> {{
     def render(self, mono):
         return '''\
         "{}" => Intrinsic {{
-            inputs: vec![{}],
+            inputs: {{ static INPUTS: [&'static Type; {}] = [{}]; &INPUTS }},
             output: {},
             definition: Named("{}")
         }},'''.format(mono.intrinsic_suffix(),
+                      len(mono._args_raw),
                       mono.compiler_args(),
                       mono.compiler_ret(),
                       mono.llvm_name())
index ceab0ed30e7199db8335b8828586f8a9065f1f5a..59986a905a2ecfc8eae21e08bd41d5df56cb3429 100644 (file)
@@ -13,7 +13,7 @@
 
 #![allow(unused_imports)]
 
-use {Intrinsic, i, i_, u, u_, f, v, v_, agg, p, void};
+use {Intrinsic, Type};
 use IntrinsicDef::Named;
 use rustc::middle::ty::TyCtxt;
 
@@ -24,3393 +24,3393 @@ pub fn find<'tcx>(_tcx: &TyCtxt<'tcx>, name: &str) -> Option<Intrinsic> {
     if !name.starts_with("aarch64_v") { return None }
     Some(match &name["aarch64_v".len()..] {
         "hadd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.shadd.v8i8")
         },
         "hadd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uhadd.v8i8")
         },
         "hadd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.shadd.v4i16")
         },
         "hadd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uhadd.v4i16")
         },
         "hadd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.shadd.v2i32")
         },
         "hadd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uhadd.v2i32")
         },
         "haddq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.shadd.v16i8")
         },
         "haddq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.uhadd.v16i8")
         },
         "haddq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.shadd.v8i16")
         },
         "haddq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uhadd.v8i16")
         },
         "haddq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.shadd.v4i32")
         },
         "haddq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uhadd.v4i32")
         },
         "rhadd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.srhadd.v8i8")
         },
         "rhadd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.urhadd.v8i8")
         },
         "rhadd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.srhadd.v4i16")
         },
         "rhadd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.urhadd.v4i16")
         },
         "rhadd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.srhadd.v2i32")
         },
         "rhadd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.urhadd.v2i32")
         },
         "rhaddq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.srhadd.v16i8")
         },
         "rhaddq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.urhadd.v16i8")
         },
         "rhaddq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.srhadd.v8i16")
         },
         "rhaddq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.urhadd.v8i16")
         },
         "rhaddq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.srhadd.v4i32")
         },
         "rhaddq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.urhadd.v4i32")
         },
         "qadd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqadd.v8i8")
         },
         "qadd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uqadd.v8i8")
         },
         "qadd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqadd.v4i16")
         },
         "qadd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uqadd.v4i16")
         },
         "qadd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqadd.v2i32")
         },
         "qadd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uqadd.v2i32")
         },
         "qadd_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.sqadd.v1i64")
         },
         "qadd_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.uqadd.v1i64")
         },
         "qaddq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sqadd.v16i8")
         },
         "qaddq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.uqadd.v16i8")
         },
         "qaddq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqadd.v8i16")
         },
         "qaddq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uqadd.v8i16")
         },
         "qaddq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqadd.v4i32")
         },
         "qaddq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uqadd.v4i32")
         },
         "qaddq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.sqadd.v2i64")
         },
         "qaddq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.uqadd.v2i64")
         },
         "uqadd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.suqadd.v16i8")
         },
         "uqadd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(u(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.suqadd.v8i16")
         },
         "uqadd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(u(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.suqadd.v4i32")
         },
         "uqadd_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(u(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.suqadd.v2i64")
         },
         "sqadd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.usqadd.v16i8")
         },
         "sqadd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.usqadd.v8i16")
         },
         "sqadd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.usqadd.v4i32")
         },
         "sqadd_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.usqadd.v2i64")
         },
         "raddhn_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.raddhn.v8i8")
         },
         "raddhn_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.raddhn.v8i8")
         },
         "raddhn_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.raddhn.v4i16")
         },
         "raddhn_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.raddhn.v4i16")
         },
         "raddhn_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.raddhn.v2i32")
         },
         "raddhn_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.raddhn.v2i32")
         },
         "fmulx_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fmulx.v2f32")
         },
         "fmulx_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.fmulx.v1f64")
         },
         "fmulxq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fmulx.v4f32")
         },
         "fmulxq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fmulx.v2f64")
         },
         "fma_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.fma.v2f32")
         },
         "fma_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.fma.v1f64")
         },
         "fmaq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.fma.v4f32")
         },
         "fmaq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.fma.v2f64")
         },
         "qdmulh_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqdmulh.v4i16")
         },
         "qdmulh_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqdmulh.v2i32")
         },
         "qdmulhq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqdmulh.v8i16")
         },
         "qdmulhq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqdmulh.v4i32")
         },
         "qrdmulh_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqrdmulh.v4i16")
         },
         "qrdmulh_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqrdmulh.v2i32")
         },
         "qrdmulhq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqrdmulh.v8i16")
         },
         "qrdmulhq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqrdmulh.v4i32")
         },
         "mull_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.smull.v8i16")
         },
         "mull_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.umull.v8i16")
         },
         "mull_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.smull.v4i32")
         },
         "mull_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.umull.v4i32")
         },
         "mull_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.smull.v2i64")
         },
         "mull_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.umull.v2i64")
         },
         "qdmullq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqdmull.v8i16")
         },
         "qdmullq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqdmull.v4i32")
         },
         "hsub_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.shsub.v8i8")
         },
         "hsub_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uhsub.v8i8")
         },
         "hsub_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.shsub.v4i16")
         },
         "hsub_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uhsub.v4i16")
         },
         "hsub_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.shsub.v2i32")
         },
         "hsub_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uhsub.v2i32")
         },
         "hsubq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.shsub.v16i8")
         },
         "hsubq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.uhsub.v16i8")
         },
         "hsubq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.shsub.v8i16")
         },
         "hsubq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uhsub.v8i16")
         },
         "hsubq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.shsub.v4i32")
         },
         "hsubq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uhsub.v4i32")
         },
         "qsub_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqsub.v8i8")
         },
         "qsub_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uqsub.v8i8")
         },
         "qsub_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqsub.v4i16")
         },
         "qsub_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uqsub.v4i16")
         },
         "qsub_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqsub.v2i32")
         },
         "qsub_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uqsub.v2i32")
         },
         "qsub_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.sqsub.v1i64")
         },
         "qsub_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.uqsub.v1i64")
         },
         "qsubq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sqsub.v16i8")
         },
         "qsubq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.uqsub.v16i8")
         },
         "qsubq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqsub.v8i16")
         },
         "qsubq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uqsub.v8i16")
         },
         "qsubq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqsub.v4i32")
         },
         "qsubq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uqsub.v4i32")
         },
         "qsubq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.sqsub.v2i64")
         },
         "qsubq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.uqsub.v2i64")
         },
         "rsubhn_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.rsubhn.v8i8")
         },
         "rsubhn_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.rsubhn.v8i8")
         },
         "rsubhn_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.rsubhn.v4i16")
         },
         "rsubhn_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.rsubhn.v4i16")
         },
         "rsubhn_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.rsubhn.v2i32")
         },
         "rsubhn_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.rsubhn.v2i32")
         },
         "abd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sabd.v8i8")
         },
         "abd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uabd.v8i8")
         },
         "abd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sabd.v4i16")
         },
         "abd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uabd.v4i16")
         },
         "abd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sabd.v2i32")
         },
         "abd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uabd.v2i32")
         },
         "abd_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fabd.v2f32")
         },
         "abd_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.fabd.v1f64")
         },
         "abdq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sabd.v16i8")
         },
         "abdq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.uabd.v16i8")
         },
         "abdq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sabd.v8i16")
         },
         "abdq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uabd.v8i16")
         },
         "abdq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sabd.v4i32")
         },
         "abdq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uabd.v4i32")
         },
         "abdq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fabd.v4f32")
         },
         "abdq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fabd.v2f64")
         },
         "max_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.smax.v8i8")
         },
         "max_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.umax.v8i8")
         },
         "max_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.smax.v4i16")
         },
         "max_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.umax.v4i16")
         },
         "max_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.smax.v2i32")
         },
         "max_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.umax.v2i32")
         },
         "max_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fmax.v2f32")
         },
         "max_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.fmax.v1f64")
         },
         "maxq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.smax.v16i8")
         },
         "maxq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.umax.v16i8")
         },
         "maxq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.smax.v8i16")
         },
         "maxq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.umax.v8i16")
         },
         "maxq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.smax.v4i32")
         },
         "maxq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.umax.v4i32")
         },
         "maxq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fmax.v4f32")
         },
         "maxq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fmax.v2f64")
         },
         "min_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.smin.v8i8")
         },
         "min_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.umin.v8i8")
         },
         "min_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.smin.v4i16")
         },
         "min_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.umin.v4i16")
         },
         "min_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.smin.v2i32")
         },
         "min_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.umin.v2i32")
         },
         "min_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fmin.v2f32")
         },
         "min_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.fmin.v1f64")
         },
         "minq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.smin.v16i8")
         },
         "minq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.umin.v16i8")
         },
         "minq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.smin.v8i16")
         },
         "minq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.umin.v8i16")
         },
         "minq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.smin.v4i32")
         },
         "minq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.umin.v4i32")
         },
         "minq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fmin.v4f32")
         },
         "minq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fmin.v2f64")
         },
         "maxnm_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fmaxnm.v2f32")
         },
         "maxnm_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.fmaxnm.v1f64")
         },
         "maxnmq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fmaxnm.v4f32")
         },
         "maxnmq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fmaxnm.v2f64")
         },
         "minnm_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fminnm.v2f32")
         },
         "minnm_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.fminnm.v1f64")
         },
         "minnmq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fminnm.v4f32")
         },
         "minnmq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fminnm.v2f64")
         },
         "shl_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sshl.v8i8")
         },
         "shl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.ushl.v8i8")
         },
         "shl_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sshl.v4i16")
         },
         "shl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.ushl.v4i16")
         },
         "shl_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sshl.v2i32")
         },
         "shl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.ushl.v2i32")
         },
         "shl_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.sshl.v1i64")
         },
         "shl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.ushl.v1i64")
         },
         "shlq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sshl.v16i8")
         },
         "shlq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.ushl.v16i8")
         },
         "shlq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sshl.v8i16")
         },
         "shlq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.ushl.v8i16")
         },
         "shlq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sshl.v4i32")
         },
         "shlq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.ushl.v4i32")
         },
         "shlq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.sshl.v2i64")
         },
         "shlq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.ushl.v2i64")
         },
         "qshl_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqshl.v8i8")
         },
         "qshl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uqshl.v8i8")
         },
         "qshl_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqshl.v4i16")
         },
         "qshl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uqshl.v4i16")
         },
         "qshl_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqshl.v2i32")
         },
         "qshl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uqshl.v2i32")
         },
         "qshl_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.sqshl.v1i64")
         },
         "qshl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.uqshl.v1i64")
         },
         "qshlq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sqshl.v16i8")
         },
         "qshlq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.uqshl.v16i8")
         },
         "qshlq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqshl.v8i16")
         },
         "qshlq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uqshl.v8i16")
         },
         "qshlq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqshl.v4i32")
         },
         "qshlq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uqshl.v4i32")
         },
         "qshlq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.sqshl.v2i64")
         },
         "qshlq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.uqshl.v2i64")
         },
         "rshl_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.srshl.v8i8")
         },
         "rshl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.urshl.v8i8")
         },
         "rshl_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.srshl.v4i16")
         },
         "rshl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.urshl.v4i16")
         },
         "rshl_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.srshl.v2i32")
         },
         "rshl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.urshl.v2i32")
         },
         "rshl_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.srshl.v1i64")
         },
         "rshl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.urshl.v1i64")
         },
         "rshlq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.srshl.v16i8")
         },
         "rshlq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.urshl.v16i8")
         },
         "rshlq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.srshl.v8i16")
         },
         "rshlq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.urshl.v8i16")
         },
         "rshlq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.srshl.v4i32")
         },
         "rshlq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.urshl.v4i32")
         },
         "rshlq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.srshl.v2i64")
         },
         "rshlq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.urshl.v2i64")
         },
         "qrshl_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqrshl.v8i8")
         },
         "qrshl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uqrshl.v8i8")
         },
         "qrshl_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqrshl.v4i16")
         },
         "qrshl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uqrshl.v4i16")
         },
         "qrshl_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqrshl.v2i32")
         },
         "qrshl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uqrshl.v2i32")
         },
         "qrshl_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.sqrshl.v1i64")
         },
         "qrshl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.uqrshl.v1i64")
         },
         "qrshlq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sqrshl.v16i8")
         },
         "qrshlq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.uqrshl.v16i8")
         },
         "qrshlq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqrshl.v8i16")
         },
         "qrshlq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uqrshl.v8i16")
         },
         "qrshlq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqrshl.v4i32")
         },
         "qrshlq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uqrshl.v4i32")
         },
         "qrshlq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.sqrshl.v2i64")
         },
         "qrshlq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.uqrshl.v2i64")
         },
         "qshrun_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqshrun.v8i8")
         },
         "qshrun_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqshrun.v4i16")
         },
         "qshrun_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqshrun.v2i32")
         },
         "qrshrun_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqrshrun.v8i8")
         },
         "qrshrun_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqrshrun.v4i16")
         },
         "qrshrun_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqrshrun.v2i32")
         },
         "qshrn_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqshrn.v8i8")
         },
         "qshrn_n_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), u(32)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U32]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uqshrn.v8i8")
         },
         "qshrn_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqshrn.v4i16")
         },
         "qshrn_n_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), u(32)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uqshrn.v4i16")
         },
         "qshrn_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqshrn.v2i32")
         },
         "qshrn_n_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), u(32)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U32]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uqshrn.v2i32")
         },
         "rshrn_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.rshrn.v8i8")
         },
         "rshrn_n_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), u(32)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U32]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.rshrn.v8i8")
         },
         "rshrn_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.rshrn.v4i16")
         },
         "rshrn_n_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), u(32)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.rshrn.v4i16")
         },
         "rshrn_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.rshrn.v2i32")
         },
         "rshrn_n_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), u(32)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U32]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.rshrn.v2i32")
         },
         "qrshrn_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqrshrn.v8i8")
         },
         "qrshrn_n_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), u(32)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U32]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uqrshrn.v8i8")
         },
         "qrshrn_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqrshrn.v4i16")
         },
         "qrshrn_n_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), u(32)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uqrshrn.v4i16")
         },
         "qrshrn_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqrshrn.v2i32")
         },
         "qrshrn_n_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), u(32)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U32]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uqrshrn.v2i32")
         },
         "sri_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.vsri.v8i8")
         },
         "sri_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.vsri.v8i8")
         },
         "sri_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.vsri.v4i16")
         },
         "sri_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.vsri.v4i16")
         },
         "sri_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.vsri.v2i32")
         },
         "sri_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.vsri.v2i32")
         },
         "sri_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.vsri.v1i64")
         },
         "sri_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.vsri.v1i64")
         },
         "sriq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.vsri.v16i8")
         },
         "sriq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.vsri.v16i8")
         },
         "sriq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.vsri.v8i16")
         },
         "sriq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.vsri.v8i16")
         },
         "sriq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.vsri.v4i32")
         },
         "sriq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.vsri.v4i32")
         },
         "sriq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.vsri.v2i64")
         },
         "sriq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.vsri.v2i64")
         },
         "sli_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.vsli.v8i8")
         },
         "sli_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.vsli.v8i8")
         },
         "sli_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.vsli.v4i16")
         },
         "sli_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.vsli.v4i16")
         },
         "sli_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.vsli.v2i32")
         },
         "sli_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.vsli.v2i32")
         },
         "sli_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.vsli.v1i64")
         },
         "sli_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.vsli.v1i64")
         },
         "sliq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.vsli.v16i8")
         },
         "sliq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.vsli.v16i8")
         },
         "sliq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.vsli.v8i16")
         },
         "sliq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.vsli.v8i16")
         },
         "sliq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.vsli.v4i32")
         },
         "sliq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.vsli.v4i32")
         },
         "sliq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.vsli.v2i64")
         },
         "sliq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.vsli.v2i64")
         },
         "vqmovn_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqxtn.v8i8")
         },
         "vqmovn_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uqxtn.v8i8")
         },
         "vqmovn_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqxtn.v4i16")
         },
         "vqmovn_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uqxtn.v4i16")
         },
         "vqmovn_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqxtn.v2i32")
         },
         "vqmovn_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U64x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uqxtn.v2i32")
         },
         "abs_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.abs.v8i8")
         },
         "abs_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.abs.v4i16")
         },
         "abs_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.abs.v2i32")
         },
         "abs_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.abs.v1i64")
         },
         "absq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.abs.v16i8")
         },
         "absq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.abs.v8i16")
         },
         "absq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.abs.v4i32")
         },
         "absq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.abs.v2i64")
         },
         "abs_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.fabs.v2f32")
         },
         "abs_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.fabs.v1f64")
         },
         "absq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.fabs.v4f32")
         },
         "absq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.fabs.v2f64")
         },
         "qabs_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqabs.v8i8")
         },
         "qabs_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqabs.v4i16")
         },
         "qabs_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqabs.v2i32")
         },
         "qabs_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.sqabs.v1i64")
         },
         "qabsq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sqabs.v16i8")
         },
         "qabsq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqabs.v8i16")
         },
         "qabsq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqabs.v4i32")
         },
         "qabsq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.sqabs.v2i64")
         },
         "qneg_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sqneg.v8i8")
         },
         "qneg_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sqneg.v4i16")
         },
         "qneg_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sqneg.v2i32")
         },
         "qneg_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.sqneg.v1i64")
         },
         "qnegq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sqneg.v16i8")
         },
         "qnegq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sqneg.v8i16")
         },
         "qnegq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sqneg.v4i32")
         },
         "qnegq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.sqneg.v2i64")
         },
         "clz_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.ctlz.v8i8")
         },
         "clz_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.ctlz.v8i8")
         },
         "clz_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.ctlz.v4i16")
         },
         "clz_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.ctlz.v4i16")
         },
         "clz_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.ctlz.v2i32")
         },
         "clz_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.ctlz.v2i32")
         },
         "clzq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.ctlz.v16i8")
         },
         "clzq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.ctlz.v16i8")
         },
         "clzq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.ctlz.v8i16")
         },
         "clzq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.ctlz.v8i16")
         },
         "clzq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.ctlz.v4i32")
         },
         "clzq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.ctlz.v4i32")
         },
         "cls_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.cls.v8i8")
         },
         "cls_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.cls.v8i8")
         },
         "cls_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.cls.v4i16")
         },
         "cls_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.cls.v4i16")
         },
         "cls_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.cls.v2i32")
         },
         "cls_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.cls.v2i32")
         },
         "clsq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.cls.v16i8")
         },
         "clsq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.cls.v16i8")
         },
         "clsq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.cls.v8i16")
         },
         "clsq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.cls.v8i16")
         },
         "clsq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.cls.v4i32")
         },
         "clsq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.cls.v4i32")
         },
         "cnt_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.ctpop.v8i8")
         },
         "cnt_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.ctpop.v8i8")
         },
         "cntq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.ctpop.v16i8")
         },
         "cntq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.ctpop.v16i8")
         },
         "recpe_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.urecpe.v2i32")
         },
         "recpe_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.frecpe.v2f32")
         },
         "recpe_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.frecpe.v1f64")
         },
         "recpeq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.urecpe.v4i32")
         },
         "recpeq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.frecpe.v4f32")
         },
         "recpeq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.frecpe.v2f64")
         },
         "recps_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.frecps.v2f32")
         },
         "recps_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.frecps.v1f64")
         },
         "recpsq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.frecps.v4f32")
         },
         "recpsq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.frecps.v2f64")
         },
         "sqrt_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.sqrt.v2f32")
         },
         "sqrt_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.sqrt.v1f64")
         },
         "sqrtq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.sqrt.v4f32")
         },
         "sqrtq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.sqrt.v2f64")
         },
         "rsqrte_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.ursqrte.v2i32")
         },
         "rsqrte_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.frsqrte.v2f32")
         },
         "rsqrte_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.frsqrte.v1f64")
         },
         "rsqrteq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.ursqrte.v4i32")
         },
         "rsqrteq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.frsqrte.v4f32")
         },
         "rsqrteq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.frsqrte.v2f64")
         },
         "rsqrts_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.frsqrts.v2f32")
         },
         "rsqrts_f64" => Intrinsic {
-            inputs: vec![v(f(64), 1), v(f(64), 1)],
-            output: v(f(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &INPUTS },
+            output: &::F64x1,
             definition: Named("llvm.aarch64.neon.frsqrts.v1f64")
         },
         "rsqrtsq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.frsqrts.v4f32")
         },
         "rsqrtsq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.frsqrts.v2f64")
         },
         "rbit_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.rbit.v8i8")
         },
         "rbit_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.rbit.v8i8")
         },
         "rbitq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.rbit.v16i8")
         },
         "rbitq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.rbit.v16i8")
         },
         "ld2_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), Some(v(i(8), 8)))],
-            output: agg(false, vec![v(i(8), 8), v(i(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, Some(&::I8x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v8i8.p0v8i8")
         },
         "ld2_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), Some(v(u(8), 8)))],
-            output: agg(false, vec![v(u(8), 8), v(u(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, Some(&::U8x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v8i8.p0v8i8")
         },
         "ld2_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), Some(v(i(16), 4)))],
-            output: agg(false, vec![v(i(16), 4), v(i(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, Some(&::I16x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4i16.p0v4i16")
         },
         "ld2_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), Some(v(u(16), 4)))],
-            output: agg(false, vec![v(u(16), 4), v(u(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, Some(&::U16x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4i16.p0v4i16")
         },
         "ld2_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), Some(v(i(32), 2)))],
-            output: agg(false, vec![v(i(32), 2), v(i(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, Some(&::I32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2i32.p0v2i32")
         },
         "ld2_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), Some(v(u(32), 2)))],
-            output: agg(false, vec![v(u(32), 2), v(u(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, Some(&::U32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2i32.p0v2i32")
         },
         "ld2_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), Some(v(i(64), 1)))],
-            output: agg(false, vec![v(i(64), 1), v(i(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, Some(&::I64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v1i64.p0v1i64")
         },
         "ld2_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), Some(v(u(64), 1)))],
-            output: agg(false, vec![v(u(64), 1), v(u(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, Some(&::U64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v1i64.p0v1i64")
         },
         "ld2_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), Some(v(f(32), 2)))],
-            output: agg(false, vec![v(f(32), 2), v(f(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::F32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2f32.p0v2f32")
         },
         "ld2_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), Some(v(f(64), 1)))],
-            output: agg(false, vec![v(f(64), 1), v(f(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::F64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v1f64.p0v1f64")
         },
         "ld2q_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), Some(v(i(8), 16)))],
-            output: agg(false, vec![v(i(8), 16), v(i(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, Some(&::I8x16), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v16i8.p0v16i8")
         },
         "ld2q_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), Some(v(u(8), 16)))],
-            output: agg(false, vec![v(u(8), 16), v(u(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, Some(&::U8x16), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v16i8.p0v16i8")
         },
         "ld2q_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), Some(v(i(16), 8)))],
-            output: agg(false, vec![v(i(16), 8), v(i(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, Some(&::I16x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v8i16.p0v8i16")
         },
         "ld2q_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), Some(v(u(16), 8)))],
-            output: agg(false, vec![v(u(16), 8), v(u(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, Some(&::U16x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v8i16.p0v8i16")
         },
         "ld2q_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), Some(v(i(32), 4)))],
-            output: agg(false, vec![v(i(32), 4), v(i(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, Some(&::I32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4i32.p0v4i32")
         },
         "ld2q_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), Some(v(u(32), 4)))],
-            output: agg(false, vec![v(u(32), 4), v(u(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, Some(&::U32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4i32.p0v4i32")
         },
         "ld2q_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), Some(v(i(64), 2)))],
-            output: agg(false, vec![v(i(64), 2), v(i(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, Some(&::I64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2i64.p0v2i64")
         },
         "ld2q_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), Some(v(u(64), 2)))],
-            output: agg(false, vec![v(u(64), 2), v(u(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, Some(&::U64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2i64.p0v2i64")
         },
         "ld2q_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), Some(v(f(32), 4)))],
-            output: agg(false, vec![v(f(32), 4), v(f(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::F32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4f32.p0v4f32")
         },
         "ld2q_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), Some(v(f(64), 2)))],
-            output: agg(false, vec![v(f(64), 2), v(f(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::F64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2f64.p0v2f64")
         },
         "ld3_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), Some(v(i(8), 8)))],
-            output: agg(false, vec![v(i(8), 8), v(i(8), 8), v(i(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, Some(&::I8x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I8x8, &::I8x8, &::I8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v8i8.p0v8i8")
         },
         "ld3_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), Some(v(u(8), 8)))],
-            output: agg(false, vec![v(u(8), 8), v(u(8), 8), v(u(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, Some(&::U8x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U8x8, &::U8x8, &::U8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v8i8.p0v8i8")
         },
         "ld3_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), Some(v(i(16), 4)))],
-            output: agg(false, vec![v(i(16), 4), v(i(16), 4), v(i(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, Some(&::I16x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I16x4, &::I16x4, &::I16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4i16.p0v4i16")
         },
         "ld3_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), Some(v(u(16), 4)))],
-            output: agg(false, vec![v(u(16), 4), v(u(16), 4), v(u(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, Some(&::U16x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U16x4, &::U16x4, &::U16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4i16.p0v4i16")
         },
         "ld3_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), Some(v(i(32), 2)))],
-            output: agg(false, vec![v(i(32), 2), v(i(32), 2), v(i(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, Some(&::I32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I32x2, &::I32x2, &::I32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2i32.p0v2i32")
         },
         "ld3_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), Some(v(u(32), 2)))],
-            output: agg(false, vec![v(u(32), 2), v(u(32), 2), v(u(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, Some(&::U32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U32x2, &::U32x2, &::U32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2i32.p0v2i32")
         },
         "ld3_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), Some(v(i(64), 1)))],
-            output: agg(false, vec![v(i(64), 1), v(i(64), 1), v(i(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, Some(&::I64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I64x1, &::I64x1, &::I64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v1i64.p0v1i64")
         },
         "ld3_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), Some(v(u(64), 1)))],
-            output: agg(false, vec![v(u(64), 1), v(u(64), 1), v(u(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, Some(&::U64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U64x1, &::U64x1, &::U64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v1i64.p0v1i64")
         },
         "ld3_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), Some(v(f(32), 2)))],
-            output: agg(false, vec![v(f(32), 2), v(f(32), 2), v(f(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::F32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::F32x2, &::F32x2, &::F32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2f32.p0v2f32")
         },
         "ld3_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), Some(v(f(64), 1)))],
-            output: agg(false, vec![v(f(64), 1), v(f(64), 1), v(f(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::F64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::F64x1, &::F64x1, &::F64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v1f64.p0v1f64")
         },
         "ld3q_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), Some(v(i(8), 16)))],
-            output: agg(false, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, Some(&::I8x16), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v16i8.p0v16i8")
         },
         "ld3q_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), Some(v(u(8), 16)))],
-            output: agg(false, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, Some(&::U8x16), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v16i8.p0v16i8")
         },
         "ld3q_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), Some(v(i(16), 8)))],
-            output: agg(false, vec![v(i(16), 8), v(i(16), 8), v(i(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, Some(&::I16x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I16x8, &::I16x8, &::I16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v8i16.p0v8i16")
         },
         "ld3q_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), Some(v(u(16), 8)))],
-            output: agg(false, vec![v(u(16), 8), v(u(16), 8), v(u(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, Some(&::U16x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U16x8, &::U16x8, &::U16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v8i16.p0v8i16")
         },
         "ld3q_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), Some(v(i(32), 4)))],
-            output: agg(false, vec![v(i(32), 4), v(i(32), 4), v(i(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, Some(&::I32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I32x4, &::I32x4, &::I32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4i32.p0v4i32")
         },
         "ld3q_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), Some(v(u(32), 4)))],
-            output: agg(false, vec![v(u(32), 4), v(u(32), 4), v(u(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, Some(&::U32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U32x4, &::U32x4, &::U32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4i32.p0v4i32")
         },
         "ld3q_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), Some(v(i(64), 2)))],
-            output: agg(false, vec![v(i(64), 2), v(i(64), 2), v(i(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, Some(&::I64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I64x2, &::I64x2, &::I64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2i64.p0v2i64")
         },
         "ld3q_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), Some(v(u(64), 2)))],
-            output: agg(false, vec![v(u(64), 2), v(u(64), 2), v(u(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, Some(&::U64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U64x2, &::U64x2, &::U64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2i64.p0v2i64")
         },
         "ld3q_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), Some(v(f(32), 4)))],
-            output: agg(false, vec![v(f(32), 4), v(f(32), 4), v(f(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::F32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::F32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4f32.p0v4f32")
         },
         "ld3q_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), Some(v(f(64), 2)))],
-            output: agg(false, vec![v(f(64), 2), v(f(64), 2), v(f(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::F64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::F64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2f64.p0v2f64")
         },
         "ld4_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), Some(v(i(8), 8)))],
-            output: agg(false, vec![v(i(8), 8), v(i(8), 8), v(i(8), 8), v(i(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, Some(&::I8x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I8x8, &::I8x8, &::I8x8, &::I8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v8i8.p0v8i8")
         },
         "ld4_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), Some(v(u(8), 8)))],
-            output: agg(false, vec![v(u(8), 8), v(u(8), 8), v(u(8), 8), v(u(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, Some(&::U8x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U8x8, &::U8x8, &::U8x8, &::U8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v8i8.p0v8i8")
         },
         "ld4_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), Some(v(i(16), 4)))],
-            output: agg(false, vec![v(i(16), 4), v(i(16), 4), v(i(16), 4), v(i(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, Some(&::I16x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I16x4, &::I16x4, &::I16x4, &::I16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4i16.p0v4i16")
         },
         "ld4_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), Some(v(u(16), 4)))],
-            output: agg(false, vec![v(u(16), 4), v(u(16), 4), v(u(16), 4), v(u(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, Some(&::U16x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U16x4, &::U16x4, &::U16x4, &::U16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4i16.p0v4i16")
         },
         "ld4_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), Some(v(i(32), 2)))],
-            output: agg(false, vec![v(i(32), 2), v(i(32), 2), v(i(32), 2), v(i(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, Some(&::I32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I32x2, &::I32x2, &::I32x2, &::I32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2i32.p0v2i32")
         },
         "ld4_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), Some(v(u(32), 2)))],
-            output: agg(false, vec![v(u(32), 2), v(u(32), 2), v(u(32), 2), v(u(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, Some(&::U32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U32x2, &::U32x2, &::U32x2, &::U32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2i32.p0v2i32")
         },
         "ld4_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), Some(v(i(64), 1)))],
-            output: agg(false, vec![v(i(64), 1), v(i(64), 1), v(i(64), 1), v(i(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, Some(&::I64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I64x1, &::I64x1, &::I64x1, &::I64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v1i64.p0v1i64")
         },
         "ld4_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), Some(v(u(64), 1)))],
-            output: agg(false, vec![v(u(64), 1), v(u(64), 1), v(u(64), 1), v(u(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, Some(&::U64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U64x1, &::U64x1, &::U64x1, &::U64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v1i64.p0v1i64")
         },
         "ld4_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), Some(v(f(32), 2)))],
-            output: agg(false, vec![v(f(32), 2), v(f(32), 2), v(f(32), 2), v(f(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::F32x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::F32x2, &::F32x2, &::F32x2, &::F32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2f32.p0v2f32")
         },
         "ld4_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), Some(v(f(64), 1)))],
-            output: agg(false, vec![v(f(64), 1), v(f(64), 1), v(f(64), 1), v(f(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::F64x1), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::F64x1, &::F64x1, &::F64x1, &::F64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v1f64.p0v1f64")
         },
         "ld4q_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), Some(v(i(8), 16)))],
-            output: agg(false, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16), v(i(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, Some(&::I8x16), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I8x16, &::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v16i8.p0v16i8")
         },
         "ld4q_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), Some(v(u(8), 16)))],
-            output: agg(false, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16), v(u(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, Some(&::U8x16), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U8x16, &::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v16i8.p0v16i8")
         },
         "ld4q_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), Some(v(i(16), 8)))],
-            output: agg(false, vec![v(i(16), 8), v(i(16), 8), v(i(16), 8), v(i(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, Some(&::I16x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I16x8, &::I16x8, &::I16x8, &::I16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v8i16.p0v8i16")
         },
         "ld4q_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), Some(v(u(16), 8)))],
-            output: agg(false, vec![v(u(16), 8), v(u(16), 8), v(u(16), 8), v(u(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, Some(&::U16x8), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U16x8, &::U16x8, &::U16x8, &::U16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v8i16.p0v8i16")
         },
         "ld4q_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), Some(v(i(32), 4)))],
-            output: agg(false, vec![v(i(32), 4), v(i(32), 4), v(i(32), 4), v(i(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, Some(&::I32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I32x4, &::I32x4, &::I32x4, &::I32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4i32.p0v4i32")
         },
         "ld4q_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), Some(v(u(32), 4)))],
-            output: agg(false, vec![v(u(32), 4), v(u(32), 4), v(u(32), 4), v(u(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, Some(&::U32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U32x4, &::U32x4, &::U32x4, &::U32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4i32.p0v4i32")
         },
         "ld4q_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), Some(v(i(64), 2)))],
-            output: agg(false, vec![v(i(64), 2), v(i(64), 2), v(i(64), 2), v(i(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, Some(&::I64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I64x2, &::I64x2, &::I64x2, &::I64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2i64.p0v2i64")
         },
         "ld4q_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), Some(v(u(64), 2)))],
-            output: agg(false, vec![v(u(64), 2), v(u(64), 2), v(u(64), 2), v(u(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, Some(&::U64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U64x2, &::U64x2, &::U64x2, &::U64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2i64.p0v2i64")
         },
         "ld4q_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), Some(v(f(32), 4)))],
-            output: agg(false, vec![v(f(32), 4), v(f(32), 4), v(f(32), 4), v(f(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::F32x4), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::F32x4, &::F32x4, &::F32x4, &::F32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4f32.p0v4f32")
         },
         "ld4q_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), Some(v(f(64), 2)))],
-            output: agg(false, vec![v(f(64), 2), v(f(64), 2), v(f(64), 2), v(f(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::F64x2), true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::F64x2, &::F64x2, &::F64x2, &::F64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2f64.p0v2f64")
         },
         "ld2_dup_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), None)],
-            output: agg(false, vec![v(i(8), 8), v(i(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v8i8.p0i8")
         },
         "ld2_dup_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), None)],
-            output: agg(false, vec![v(u(8), 8), v(u(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v8i8.p0i8")
         },
         "ld2_dup_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), None)],
-            output: agg(false, vec![v(i(16), 4), v(i(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4i16.p0i16")
         },
         "ld2_dup_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), None)],
-            output: agg(false, vec![v(u(16), 4), v(u(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4i16.p0i16")
         },
         "ld2_dup_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), None)],
-            output: agg(false, vec![v(i(32), 2), v(i(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2i32.p0i32")
         },
         "ld2_dup_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), None)],
-            output: agg(false, vec![v(u(32), 2), v(u(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2i32.p0i32")
         },
         "ld2_dup_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), None)],
-            output: agg(false, vec![v(i(64), 1), v(i(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v1i64.p0i64")
         },
         "ld2_dup_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), None)],
-            output: agg(false, vec![v(u(64), 1), v(u(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v1i64.p0i64")
         },
         "ld2_dup_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), None)],
-            output: agg(false, vec![v(f(32), 2), v(f(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2f32.p0f32")
         },
         "ld2_dup_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), None)],
-            output: agg(false, vec![v(f(64), 1), v(f(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::F64x1, &::F64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v1f64.p0f64")
         },
         "ld2q_dup_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), None)],
-            output: agg(false, vec![v(i(8), 16), v(i(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v16i8.p0i8")
         },
         "ld2q_dup_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), None)],
-            output: agg(false, vec![v(u(8), 16), v(u(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v16i8.p0i8")
         },
         "ld2q_dup_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), None)],
-            output: agg(false, vec![v(i(16), 8), v(i(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v8i16.p0i16")
         },
         "ld2q_dup_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), None)],
-            output: agg(false, vec![v(u(16), 8), v(u(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v8i16.p0i16")
         },
         "ld2q_dup_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), None)],
-            output: agg(false, vec![v(i(32), 4), v(i(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4i32.p0i32")
         },
         "ld2q_dup_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), None)],
-            output: agg(false, vec![v(u(32), 4), v(u(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4i32.p0i32")
         },
         "ld2q_dup_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), None)],
-            output: agg(false, vec![v(i(64), 2), v(i(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2i64.p0i64")
         },
         "ld2q_dup_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), None)],
-            output: agg(false, vec![v(u(64), 2), v(u(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2i64.p0i64")
         },
         "ld2q_dup_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), None)],
-            output: agg(false, vec![v(f(32), 4), v(f(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v4f32.p0f32")
         },
         "ld2q_dup_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), None)],
-            output: agg(false, vec![v(f(64), 2), v(f(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld2.v2f64.p0f64")
         },
         "ld3_dup_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), None)],
-            output: agg(false, vec![v(i(8), 8), v(i(8), 8), v(i(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I8x8, &::I8x8, &::I8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v8i8.p0i8")
         },
         "ld3_dup_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), None)],
-            output: agg(false, vec![v(u(8), 8), v(u(8), 8), v(u(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U8x8, &::U8x8, &::U8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v8i8.p0i8")
         },
         "ld3_dup_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), None)],
-            output: agg(false, vec![v(i(16), 4), v(i(16), 4), v(i(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I16x4, &::I16x4, &::I16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4i16.p0i16")
         },
         "ld3_dup_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), None)],
-            output: agg(false, vec![v(u(16), 4), v(u(16), 4), v(u(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U16x4, &::U16x4, &::U16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4i16.p0i16")
         },
         "ld3_dup_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), None)],
-            output: agg(false, vec![v(i(32), 2), v(i(32), 2), v(i(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I32x2, &::I32x2, &::I32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2i32.p0i32")
         },
         "ld3_dup_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), None)],
-            output: agg(false, vec![v(u(32), 2), v(u(32), 2), v(u(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U32x2, &::U32x2, &::U32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2i32.p0i32")
         },
         "ld3_dup_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), None)],
-            output: agg(false, vec![v(i(64), 1), v(i(64), 1), v(i(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I64x1, &::I64x1, &::I64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v1i64.p0i64")
         },
         "ld3_dup_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), None)],
-            output: agg(false, vec![v(u(64), 1), v(u(64), 1), v(u(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U64x1, &::U64x1, &::U64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v1i64.p0i64")
         },
         "ld3_dup_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), None)],
-            output: agg(false, vec![v(f(32), 2), v(f(32), 2), v(f(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::F32x2, &::F32x2, &::F32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2f32.p0f32")
         },
         "ld3_dup_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), None)],
-            output: agg(false, vec![v(f(64), 1), v(f(64), 1), v(f(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::F64x1, &::F64x1, &::F64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v1f64.p0f64")
         },
         "ld3q_dup_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), None)],
-            output: agg(false, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v16i8.p0i8")
         },
         "ld3q_dup_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), None)],
-            output: agg(false, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v16i8.p0i8")
         },
         "ld3q_dup_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), None)],
-            output: agg(false, vec![v(i(16), 8), v(i(16), 8), v(i(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I16x8, &::I16x8, &::I16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v8i16.p0i16")
         },
         "ld3q_dup_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), None)],
-            output: agg(false, vec![v(u(16), 8), v(u(16), 8), v(u(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U16x8, &::U16x8, &::U16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v8i16.p0i16")
         },
         "ld3q_dup_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), None)],
-            output: agg(false, vec![v(i(32), 4), v(i(32), 4), v(i(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I32x4, &::I32x4, &::I32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4i32.p0i32")
         },
         "ld3q_dup_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), None)],
-            output: agg(false, vec![v(u(32), 4), v(u(32), 4), v(u(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U32x4, &::U32x4, &::U32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4i32.p0i32")
         },
         "ld3q_dup_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), None)],
-            output: agg(false, vec![v(i(64), 2), v(i(64), 2), v(i(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::I64x2, &::I64x2, &::I64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2i64.p0i64")
         },
         "ld3q_dup_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), None)],
-            output: agg(false, vec![v(u(64), 2), v(u(64), 2), v(u(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::U64x2, &::U64x2, &::U64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2i64.p0i64")
         },
         "ld3q_dup_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), None)],
-            output: agg(false, vec![v(f(32), 4), v(f(32), 4), v(f(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::F32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v4f32.p0f32")
         },
         "ld3q_dup_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), None)],
-            output: agg(false, vec![v(f(64), 2), v(f(64), 2), v(f(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::F64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld3.v2f64.p0f64")
         },
         "ld4_dup_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), None)],
-            output: agg(false, vec![v(i(8), 8), v(i(8), 8), v(i(8), 8), v(i(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I8x8, &::I8x8, &::I8x8, &::I8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v8i8.p0i8")
         },
         "ld4_dup_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), None)],
-            output: agg(false, vec![v(u(8), 8), v(u(8), 8), v(u(8), 8), v(u(8), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U8x8, &::U8x8, &::U8x8, &::U8x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v8i8.p0i8")
         },
         "ld4_dup_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), None)],
-            output: agg(false, vec![v(i(16), 4), v(i(16), 4), v(i(16), 4), v(i(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I16x4, &::I16x4, &::I16x4, &::I16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4i16.p0i16")
         },
         "ld4_dup_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), None)],
-            output: agg(false, vec![v(u(16), 4), v(u(16), 4), v(u(16), 4), v(u(16), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U16x4, &::U16x4, &::U16x4, &::U16x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4i16.p0i16")
         },
         "ld4_dup_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), None)],
-            output: agg(false, vec![v(i(32), 2), v(i(32), 2), v(i(32), 2), v(i(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I32x2, &::I32x2, &::I32x2, &::I32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2i32.p0i32")
         },
         "ld4_dup_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), None)],
-            output: agg(false, vec![v(u(32), 2), v(u(32), 2), v(u(32), 2), v(u(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U32x2, &::U32x2, &::U32x2, &::U32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2i32.p0i32")
         },
         "ld4_dup_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), None)],
-            output: agg(false, vec![v(i(64), 1), v(i(64), 1), v(i(64), 1), v(i(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I64x1, &::I64x1, &::I64x1, &::I64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v1i64.p0i64")
         },
         "ld4_dup_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), None)],
-            output: agg(false, vec![v(u(64), 1), v(u(64), 1), v(u(64), 1), v(u(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U64x1, &::U64x1, &::U64x1, &::U64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v1i64.p0i64")
         },
         "ld4_dup_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), None)],
-            output: agg(false, vec![v(f(32), 2), v(f(32), 2), v(f(32), 2), v(f(32), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::F32x2, &::F32x2, &::F32x2, &::F32x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2f32.p0f32")
         },
         "ld4_dup_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), None)],
-            output: agg(false, vec![v(f(64), 1), v(f(64), 1), v(f(64), 1), v(f(64), 1)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::F64x1, &::F64x1, &::F64x1, &::F64x1]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v1f64.p0f64")
         },
         "ld4q_dup_s8" => Intrinsic {
-            inputs: vec![p(true, i(8), None)],
-            output: agg(false, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16), v(i(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I8x16, &::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v16i8.p0i8")
         },
         "ld4q_dup_u8" => Intrinsic {
-            inputs: vec![p(true, u(8), None)],
-            output: agg(false, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16), v(u(8), 16)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U8x16, &::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v16i8.p0i8")
         },
         "ld4q_dup_s16" => Intrinsic {
-            inputs: vec![p(true, i(16), None)],
-            output: agg(false, vec![v(i(16), 8), v(i(16), 8), v(i(16), 8), v(i(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I16x8, &::I16x8, &::I16x8, &::I16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v8i16.p0i16")
         },
         "ld4q_dup_u16" => Intrinsic {
-            inputs: vec![p(true, u(16), None)],
-            output: agg(false, vec![v(u(16), 8), v(u(16), 8), v(u(16), 8), v(u(16), 8)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U16, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U16x8, &::U16x8, &::U16x8, &::U16x8]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v8i16.p0i16")
         },
         "ld4q_dup_s32" => Intrinsic {
-            inputs: vec![p(true, i(32), None)],
-            output: agg(false, vec![v(i(32), 4), v(i(32), 4), v(i(32), 4), v(i(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I32x4, &::I32x4, &::I32x4, &::I32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4i32.p0i32")
         },
         "ld4q_dup_u32" => Intrinsic {
-            inputs: vec![p(true, u(32), None)],
-            output: agg(false, vec![v(u(32), 4), v(u(32), 4), v(u(32), 4), v(u(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U32x4, &::U32x4, &::U32x4, &::U32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4i32.p0i32")
         },
         "ld4q_dup_s64" => Intrinsic {
-            inputs: vec![p(true, i(64), None)],
-            output: agg(false, vec![v(i(64), 2), v(i(64), 2), v(i(64), 2), v(i(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::I64x2, &::I64x2, &::I64x2, &::I64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2i64.p0i64")
         },
         "ld4q_dup_u64" => Intrinsic {
-            inputs: vec![p(true, u(64), None)],
-            output: agg(false, vec![v(u(64), 2), v(u(64), 2), v(u(64), 2), v(u(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::U64x2, &::U64x2, &::U64x2, &::U64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2i64.p0i64")
         },
         "ld4q_dup_f32" => Intrinsic {
-            inputs: vec![p(true, f(32), None)],
-            output: agg(false, vec![v(f(32), 4), v(f(32), 4), v(f(32), 4), v(f(32), 4)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F32, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::F32x4, &::F32x4, &::F32x4, &::F32x4]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v4f32.p0f32")
         },
         "ld4q_dup_f64" => Intrinsic {
-            inputs: vec![p(true, f(64), None)],
-            output: agg(false, vec![v(f(64), 2), v(f(64), 2), v(f(64), 2), v(f(64), 2)]),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::F64, None, true); &PTR }]; &INPUTS },
+            output: { static AGG: Type = Type::Aggregate(false, { static PARTS: [&'static Type; 4] = [&::F64x2, &::F64x2, &::F64x2, &::F64x2]; &PARTS }); &AGG },
             definition: Named("llvm.aarch64.neon.ld4.v2f64.p0f64")
         },
         "padd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.addp.v8i8")
         },
         "padd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.addp.v8i8")
         },
         "padd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.addp.v4i16")
         },
         "padd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.addp.v4i16")
         },
         "padd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.addp.v2i32")
         },
         "padd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.addp.v2i32")
         },
         "padd_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.addp.v2f32")
         },
         "paddq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.addp.v16i8")
         },
         "paddq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.addp.v16i8")
         },
         "paddq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.addp.v8i16")
         },
         "paddq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.addp.v8i16")
         },
         "paddq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.addp.v4i32")
         },
         "paddq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.addp.v4i32")
         },
         "paddq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.addp.v4f32")
         },
         "paddq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.addp.v2i64")
         },
         "paddq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.addp.v2i64")
         },
         "paddq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.addp.v2f64")
         },
         "paddl_s16" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.saddlp.v4i16.v8i8")
         },
         "paddl_u16" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uaddlp.v4i16.v8i8")
         },
         "paddl_s32" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.saddlp.v2i32.v4i16")
         },
         "paddl_u32" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uaddlp.v2i32.v4i16")
         },
         "paddl_s64" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.aarch64.neon.saddlp.v1i64.v2i32")
         },
         "paddl_u64" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.aarch64.neon.uaddlp.v1i64.v2i32")
         },
         "paddlq_s16" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.saddlp.v8i16.v16i8")
         },
         "paddlq_u16" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uaddlp.v8i16.v16i8")
         },
         "paddlq_s32" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.saddlp.v4i32.v8i16")
         },
         "paddlq_u32" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uaddlp.v4i32.v8i16")
         },
         "paddlq_s64" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.saddlp.v2i64.v4i32")
         },
         "paddlq_u64" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.uaddlp.v2i64.v4i32")
         },
         "pmax_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.smaxp.v8i8")
         },
         "pmax_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.umaxp.v8i8")
         },
         "pmax_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.smaxp.v4i16")
         },
         "pmax_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.umaxp.v4i16")
         },
         "pmax_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.smaxp.v2i32")
         },
         "pmax_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.umaxp.v2i32")
         },
         "pmax_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fmaxp.v2f32")
         },
         "pmaxq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.smaxp.v16i8")
         },
         "pmaxq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.umaxp.v16i8")
         },
         "pmaxq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.smaxp.v8i16")
         },
         "pmaxq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.umaxp.v8i16")
         },
         "pmaxq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.smaxp.v4i32")
         },
         "pmaxq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.umaxp.v4i32")
         },
         "pmaxq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fmaxp.v4f32")
         },
         "pmaxq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.smaxp.v2i64")
         },
         "pmaxq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.umaxp.v2i64")
         },
         "pmaxq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fmaxp.v2f64")
         },
         "pmin_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.sminp.v8i8")
         },
         "pmin_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.uminp.v8i8")
         },
         "pmin_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.sminp.v4i16")
         },
         "pmin_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.uminp.v4i16")
         },
         "pmin_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.sminp.v2i32")
         },
         "pmin_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.uminp.v2i32")
         },
         "pmin_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fminp.v2f32")
         },
         "pminq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.sminp.v16i8")
         },
         "pminq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.uminp.v16i8")
         },
         "pminq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.sminp.v8i16")
         },
         "pminq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.uminp.v8i16")
         },
         "pminq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.sminp.v4i32")
         },
         "pminq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.uminp.v4i32")
         },
         "pminq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fminp.v4f32")
         },
         "pminq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.sminp.v2i64")
         },
         "pminq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.uminp.v2i64")
         },
         "pminq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fminp.v2f64")
         },
         "pmaxnm_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.smaxnmp.v8i8")
         },
         "pmaxnm_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.umaxnmp.v8i8")
         },
         "pmaxnm_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.aarch64.neon.smaxnmp.v4i16")
         },
         "pmaxnm_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.aarch64.neon.umaxnmp.v4i16")
         },
         "pmaxnm_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.aarch64.neon.smaxnmp.v2i32")
         },
         "pmaxnm_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.aarch64.neon.umaxnmp.v2i32")
         },
         "pmaxnm_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fmaxnmp.v2f32")
         },
         "pmaxnmq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.smaxnmp.v16i8")
         },
         "pmaxnmq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.umaxnmp.v16i8")
         },
         "pmaxnmq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.aarch64.neon.smaxnmp.v8i16")
         },
         "pmaxnmq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.aarch64.neon.umaxnmp.v8i16")
         },
         "pmaxnmq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.aarch64.neon.smaxnmp.v4i32")
         },
         "pmaxnmq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.aarch64.neon.umaxnmp.v4i32")
         },
         "pmaxnmq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fmaxnmp.v4f32")
         },
         "pmaxnmq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.aarch64.neon.smaxnmp.v2i64")
         },
         "pmaxnmq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.aarch64.neon.umaxnmp.v2i64")
         },
         "pmaxnmq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fmaxnmp.v2f64")
         },
         "pminnm_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.aarch64.neon.fminnmp.v2f32")
         },
         "pminnmq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.aarch64.neon.fminnmp.v4f32")
         },
         "pminnmq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.aarch64.neon.fminnmp.v2f64")
         },
         "addv_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: i(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8,
             definition: Named("llvm.aarch64.neon.saddv.i8.v8i8")
         },
         "addv_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: u(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8,
             definition: Named("llvm.aarch64.neon.uaddv.i8.v8i8")
         },
         "addv_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: i(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16,
             definition: Named("llvm.aarch64.neon.saddv.i16.v4i16")
         },
         "addv_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: u(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U16,
             definition: Named("llvm.aarch64.neon.uaddv.i16.v4i16")
         },
         "addv_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.aarch64.neon.saddv.i32.v2i32")
         },
         "addv_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: u(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32,
             definition: Named("llvm.aarch64.neon.uaddv.i32.v2i32")
         },
         "addv_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.faddv.f32.v2f32")
         },
         "addvq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: i(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8,
             definition: Named("llvm.aarch64.neon.saddv.i8.v16i8")
         },
         "addvq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: u(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8,
             definition: Named("llvm.aarch64.neon.uaddv.i8.v16i8")
         },
         "addvq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: i(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16,
             definition: Named("llvm.aarch64.neon.saddv.i16.v8i16")
         },
         "addvq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: u(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U16,
             definition: Named("llvm.aarch64.neon.uaddv.i16.v8i16")
         },
         "addvq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.aarch64.neon.saddv.i32.v4i32")
         },
         "addvq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: u(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32,
             definition: Named("llvm.aarch64.neon.uaddv.i32.v4i32")
         },
         "addvq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.faddv.f32.v4f32")
         },
         "addvq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2)],
-            output: i(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x2]; &INPUTS },
+            output: &::I64,
             definition: Named("llvm.aarch64.neon.saddv.i64.v2i64")
         },
         "addvq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2)],
-            output: u(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U64x2]; &INPUTS },
+            output: &::U64,
             definition: Named("llvm.aarch64.neon.uaddv.i64.v2i64")
         },
         "addvq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: f(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64,
             definition: Named("llvm.aarch64.neon.faddv.f64.v2f64")
         },
         "addlv_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: i(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I16,
             definition: Named("llvm.aarch64.neon.saddlv.i16.v8i8")
         },
         "addlv_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: u(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U16,
             definition: Named("llvm.aarch64.neon.uaddlv.i16.v8i8")
         },
         "addlv_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.aarch64.neon.saddlv.i32.v4i16")
         },
         "addlv_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: u(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U32,
             definition: Named("llvm.aarch64.neon.uaddlv.i32.v4i16")
         },
         "addlv_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: i(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I64,
             definition: Named("llvm.aarch64.neon.saddlv.i64.v2i32")
         },
         "addlv_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: u(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U64,
             definition: Named("llvm.aarch64.neon.uaddlv.i64.v2i32")
         },
         "addlvq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: i(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I16,
             definition: Named("llvm.aarch64.neon.saddlv.i16.v16i8")
         },
         "addlvq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: u(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U16,
             definition: Named("llvm.aarch64.neon.uaddlv.i16.v16i8")
         },
         "addlvq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.aarch64.neon.saddlv.i32.v8i16")
         },
         "addlvq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: u(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U32,
             definition: Named("llvm.aarch64.neon.uaddlv.i32.v8i16")
         },
         "addlvq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: i(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I64,
             definition: Named("llvm.aarch64.neon.saddlv.i64.v4i32")
         },
         "addlvq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: u(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U64,
             definition: Named("llvm.aarch64.neon.uaddlv.i64.v4i32")
         },
         "maxv_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: i(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8,
             definition: Named("llvm.aarch64.neon.smaxv.i8.v8i8")
         },
         "maxv_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: u(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8,
             definition: Named("llvm.aarch64.neon.umaxv.i8.v8i8")
         },
         "maxv_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: i(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16,
             definition: Named("llvm.aarch64.neon.smaxv.i16.v4i16")
         },
         "maxv_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: u(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U16,
             definition: Named("llvm.aarch64.neon.umaxv.i16.v4i16")
         },
         "maxv_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.aarch64.neon.smaxv.i32.v2i32")
         },
         "maxv_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: u(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32,
             definition: Named("llvm.aarch64.neon.umaxv.i32.v2i32")
         },
         "maxv_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.fmaxv.f32.v2f32")
         },
         "maxvq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: i(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8,
             definition: Named("llvm.aarch64.neon.smaxv.i8.v16i8")
         },
         "maxvq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: u(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8,
             definition: Named("llvm.aarch64.neon.umaxv.i8.v16i8")
         },
         "maxvq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: i(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16,
             definition: Named("llvm.aarch64.neon.smaxv.i16.v8i16")
         },
         "maxvq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: u(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U16,
             definition: Named("llvm.aarch64.neon.umaxv.i16.v8i16")
         },
         "maxvq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.aarch64.neon.smaxv.i32.v4i32")
         },
         "maxvq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: u(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32,
             definition: Named("llvm.aarch64.neon.umaxv.i32.v4i32")
         },
         "maxvq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.fmaxv.f32.v4f32")
         },
         "maxvq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: f(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64,
             definition: Named("llvm.aarch64.neon.fmaxv.f64.v2f64")
         },
         "minv_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: i(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8,
             definition: Named("llvm.aarch64.neon.sminv.i8.v8i8")
         },
         "minv_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: u(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8,
             definition: Named("llvm.aarch64.neon.uminv.i8.v8i8")
         },
         "minv_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: i(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16,
             definition: Named("llvm.aarch64.neon.sminv.i16.v4i16")
         },
         "minv_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: u(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U16,
             definition: Named("llvm.aarch64.neon.uminv.i16.v4i16")
         },
         "minv_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.aarch64.neon.sminv.i32.v2i32")
         },
         "minv_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: u(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32,
             definition: Named("llvm.aarch64.neon.uminv.i32.v2i32")
         },
         "minv_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.fminv.f32.v2f32")
         },
         "minvq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: i(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8,
             definition: Named("llvm.aarch64.neon.sminv.i8.v16i8")
         },
         "minvq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: u(8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8,
             definition: Named("llvm.aarch64.neon.uminv.i8.v16i8")
         },
         "minvq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: i(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16,
             definition: Named("llvm.aarch64.neon.sminv.i16.v8i16")
         },
         "minvq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: u(16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U16,
             definition: Named("llvm.aarch64.neon.uminv.i16.v8i16")
         },
         "minvq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.aarch64.neon.sminv.i32.v4i32")
         },
         "minvq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: u(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32,
             definition: Named("llvm.aarch64.neon.uminv.i32.v4i32")
         },
         "minvq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.fminv.f32.v4f32")
         },
         "minvq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: f(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64,
             definition: Named("llvm.aarch64.neon.fminv.f64.v2f64")
         },
         "maxnmv_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.fmaxnmv.f32.v2f32")
         },
         "maxnmvq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.fmaxnmv.f32.v4f32")
         },
         "maxnmvq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: f(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64,
             definition: Named("llvm.aarch64.neon.fmaxnmv.f64.v2f64")
         },
         "minnmv_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.fminnmv.f32.v2f32")
         },
         "minnmvq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: f(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32,
             definition: Named("llvm.aarch64.neon.fminnmv.f32.v4f32")
         },
         "minnmvq_f64" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: f(64),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64,
             definition: Named("llvm.aarch64.neon.fminnmv.f64.v2f64")
         },
         "qtbl1_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.tbl1.v8i8")
         },
         "qtbl1_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.tbl1.v8i8")
         },
         "qtbl1q_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.tbl1.v16i8")
         },
         "qtbl1q_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.tbl1.v16i8")
         },
         "qtbx1_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 16), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x8, &::I8x16, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.tbx1.v8i8")
         },
         "qtbx1_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 16), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x8, &::U8x16, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.tbx1.v8i8")
         },
         "qtbx1q_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.tbx1.v16i8")
         },
         "qtbx1q_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x16, &::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.tbx1.v16i8")
         },
         "qtbl2_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 16), v(i(8), 16)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.tbl2.v8i8")
         },
         "qtbl2_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 16), v(u(8), 16)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.tbl2.v8i8")
         },
         "qtbl2q_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 16), v(i(8), 16)]), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.tbl2.v16i8")
         },
         "qtbl2q_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 16), v(u(8), 16)]), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.tbl2.v16i8")
         },
         "qtbx2_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 16), v(i(8), 16)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.tbx2.v8i8")
         },
         "qtbx2_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 16), v(u(8), 16)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.tbx2.v8i8")
         },
         "qtbx2q_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 16), v(i(8), 16)]), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.tbx2.v16i8")
         },
         "qtbx2q_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 16), v(u(8), 16)]), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.tbx2.v16i8")
         },
         "qtbl3_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.tbl3.v8i8")
         },
         "qtbl3_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.tbl3.v8i8")
         },
         "qtbl3q_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16)]), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.tbl3.v16i8")
         },
         "qtbl3q_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16)]), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.tbl3.v16i8")
         },
         "qtbx3_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), agg(true, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x8, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.tbx3.v8i8")
         },
         "qtbx3_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), agg(true, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x8, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.tbx3.v8i8")
         },
         "qtbx3q_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), agg(true, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16)]), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.tbx3.v16i8")
         },
         "qtbx3q_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), agg(true, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16)]), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x16, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.tbx3.v16i8")
         },
         "qtbl4_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16), v(i(8), 16)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::I8x16, &::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.tbl4.v8i8")
         },
         "qtbl4_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16), v(u(8), 16)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::U8x16, &::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.tbl4.v8i8")
         },
         "qtbl4q_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16), v(i(8), 16)]), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::I8x16, &::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.tbl4.v16i8")
         },
         "qtbl4q_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16), v(u(8), 16)]), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::U8x16, &::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.tbl4.v16i8")
         },
         "qtbx4_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), agg(true, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16), v(i(8), 16)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x8, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::I8x16, &::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.aarch64.neon.tbx4.v8i8")
         },
         "qtbx4_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), agg(true, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16), v(u(8), 16)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x8, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::U8x16, &::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.aarch64.neon.tbx4.v8i8")
         },
         "qtbx4q_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), agg(true, vec![v(i(8), 16), v(i(8), 16), v(i(8), 16), v(i(8), 16)]), v(u(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::I8x16, &::I8x16, &::I8x16, &::I8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.aarch64.neon.tbx4.v16i8")
         },
         "qtbx4q_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), agg(true, vec![v(u(8), 16), v(u(8), 16), v(u(8), 16), v(u(8), 16)]), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x16, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::U8x16, &::U8x16, &::U8x16, &::U8x16]; &PARTS }); &AGG }, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.aarch64.neon.tbx4.v16i8")
         },
         _ => return None,
index 916f267951b501502a3482322f1a80c85f4543f4..d71f59e8e68cda2fc3077fb96293adabb6092b0a 100644 (file)
@@ -13,7 +13,7 @@
 
 #![allow(unused_imports)]
 
-use {Intrinsic, i, i_, u, u_, f, v, v_, agg, p, void};
+use {Intrinsic, Type};
 use IntrinsicDef::Named;
 use rustc::middle::ty::TyCtxt;
 
@@ -24,2063 +24,2063 @@ pub fn find<'tcx>(_tcx: &TyCtxt<'tcx>, name: &str) -> Option<Intrinsic> {
     if !name.starts_with("arm_v") { return None }
     Some(match &name["arm_v".len()..] {
         "hadd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vhadds.v8i8")
         },
         "hadd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vhaddu.v8i8")
         },
         "hadd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vhadds.v4i16")
         },
         "hadd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vhaddu.v4i16")
         },
         "hadd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vhadds.v2i32")
         },
         "hadd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vhaddu.v2i32")
         },
         "haddq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vhadds.v16i8")
         },
         "haddq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vhaddu.v16i8")
         },
         "haddq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vhadds.v8i16")
         },
         "haddq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vhaddu.v8i16")
         },
         "haddq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vhadds.v4i32")
         },
         "haddq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vhaddu.v4i32")
         },
         "rhadd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vrhadds.v8i8")
         },
         "rhadd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vrhaddu.v8i8")
         },
         "rhadd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vrhadds.v4i16")
         },
         "rhadd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vrhaddu.v4i16")
         },
         "rhadd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vrhadds.v2i32")
         },
         "rhadd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vrhaddu.v2i32")
         },
         "rhaddq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vrhadds.v16i8")
         },
         "rhaddq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vrhaddu.v16i8")
         },
         "rhaddq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vrhadds.v8i16")
         },
         "rhaddq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vrhaddu.v8i16")
         },
         "rhaddq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vrhadds.v4i32")
         },
         "rhaddq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vrhaddu.v4i32")
         },
         "qadd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vqadds.v8i8")
         },
         "qadd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vqaddu.v8i8")
         },
         "qadd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vqadds.v4i16")
         },
         "qadd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vqaddu.v4i16")
         },
         "qadd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vqadds.v2i32")
         },
         "qadd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vqaddu.v2i32")
         },
         "qadd_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vqadds.v1i64")
         },
         "qadd_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vqaddu.v1i64")
         },
         "qaddq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vqadds.v16i8")
         },
         "qaddq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vqaddu.v16i8")
         },
         "qaddq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vqadds.v8i16")
         },
         "qaddq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vqaddu.v8i16")
         },
         "qaddq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vqadds.v4i32")
         },
         "qaddq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vqaddu.v4i32")
         },
         "qaddq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vqadds.v2i64")
         },
         "qaddq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vqaddu.v2i64")
         },
         "raddhn_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vraddhn.v8i8")
         },
         "raddhn_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vraddhn.v8i8")
         },
         "raddhn_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vraddhn.v4i16")
         },
         "raddhn_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vraddhn.v4i16")
         },
         "raddhn_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vraddhn.v2i32")
         },
         "raddhn_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vraddhn.v2i32")
         },
         "fma_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.fma.v2f32")
         },
         "fmaq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.fma.v4f32")
         },
         "qdmulh_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vsqdmulh.v4i16")
         },
         "qdmulh_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vsqdmulh.v2i32")
         },
         "qdmulhq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vsqdmulh.v8i16")
         },
         "qdmulhq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vsqdmulh.v4i32")
         },
         "qrdmulh_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vsqrdmulh.v4i16")
         },
         "qrdmulh_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vsqrdmulh.v2i32")
         },
         "qrdmulhq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vsqrdmulh.v8i16")
         },
         "qrdmulhq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vsqrdmulh.v4i32")
         },
         "mull_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vmulls.v8i16")
         },
         "mull_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vmullu.v8i16")
         },
         "mull_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vmulls.v4i32")
         },
         "mull_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vmullu.v4i32")
         },
         "mull_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vmulls.v2i64")
         },
         "mull_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vmullu.v2i64")
         },
         "qdmullq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vsqdmull.v8i16")
         },
         "qdmullq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vsqdmull.v4i32")
         },
         "hsub_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vhsubs.v8i8")
         },
         "hsub_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vhsubu.v8i8")
         },
         "hsub_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vhsubs.v4i16")
         },
         "hsub_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vhsubu.v4i16")
         },
         "hsub_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vhsubs.v2i32")
         },
         "hsub_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vhsubu.v2i32")
         },
         "hsubq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vhsubs.v16i8")
         },
         "hsubq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vhsubu.v16i8")
         },
         "hsubq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vhsubs.v8i16")
         },
         "hsubq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vhsubu.v8i16")
         },
         "hsubq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vhsubs.v4i32")
         },
         "hsubq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vhsubu.v4i32")
         },
         "qsub_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vqsubs.v8i8")
         },
         "qsub_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vqsubu.v8i8")
         },
         "qsub_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vqsubs.v4i16")
         },
         "qsub_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vqsubu.v4i16")
         },
         "qsub_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vqsubs.v2i32")
         },
         "qsub_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vqsubu.v2i32")
         },
         "qsub_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vqsubs.v1i64")
         },
         "qsub_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vqsubu.v1i64")
         },
         "qsubq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vqsubs.v16i8")
         },
         "qsubq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vqsubu.v16i8")
         },
         "qsubq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vqsubs.v8i16")
         },
         "qsubq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vqsubu.v8i16")
         },
         "qsubq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vqsubs.v4i32")
         },
         "qsubq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vqsubu.v4i32")
         },
         "qsubq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vqsubs.v2i64")
         },
         "qsubq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vqsubu.v2i64")
         },
         "rsubhn_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vrsubhn.v8i8")
         },
         "rsubhn_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vrsubhn.v8i8")
         },
         "rsubhn_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vrsubhn.v4i16")
         },
         "rsubhn_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vrsubhn.v4i16")
         },
         "rsubhn_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vrsubhn.v2i32")
         },
         "rsubhn_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vrsubhn.v2i32")
         },
         "abd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vabds.v8i8")
         },
         "abd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vabdu.v8i8")
         },
         "abd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vabds.v4i16")
         },
         "abd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vabdu.v4i16")
         },
         "abd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vabds.v2i32")
         },
         "abd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vabdu.v2i32")
         },
         "abd_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vabdf.v2f32")
         },
         "abdq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vabds.v16i8")
         },
         "abdq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vabdu.v16i8")
         },
         "abdq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vabds.v8i16")
         },
         "abdq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vabdu.v8i16")
         },
         "abdq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vabds.v4i32")
         },
         "abdq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vabdu.v4i32")
         },
         "abdq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.neon.vabdf.v4f32")
         },
         "max_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vmaxs.v8i8")
         },
         "max_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vmaxu.v8i8")
         },
         "max_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vmaxs.v4i16")
         },
         "max_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vmaxu.v4i16")
         },
         "max_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vmaxs.v2i32")
         },
         "max_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vmaxu.v2i32")
         },
         "max_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vmaxf.v2f32")
         },
         "maxq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vmaxs.v16i8")
         },
         "maxq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vmaxu.v16i8")
         },
         "maxq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vmaxs.v8i16")
         },
         "maxq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vmaxu.v8i16")
         },
         "maxq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vmaxs.v4i32")
         },
         "maxq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vmaxu.v4i32")
         },
         "maxq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.neon.vmaxf.v4f32")
         },
         "min_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vmins.v8i8")
         },
         "min_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vminu.v8i8")
         },
         "min_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vmins.v4i16")
         },
         "min_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vminu.v4i16")
         },
         "min_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vmins.v2i32")
         },
         "min_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vminu.v2i32")
         },
         "min_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vminf.v2f32")
         },
         "minq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vmins.v16i8")
         },
         "minq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vminu.v16i8")
         },
         "minq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vmins.v8i16")
         },
         "minq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vminu.v8i16")
         },
         "minq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vmins.v4i32")
         },
         "minq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vminu.v4i32")
         },
         "minq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.neon.vminf.v4f32")
         },
         "shl_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vshls.v8i8")
         },
         "shl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vshlu.v8i8")
         },
         "shl_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vshls.v4i16")
         },
         "shl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vshlu.v4i16")
         },
         "shl_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vshls.v2i32")
         },
         "shl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vshlu.v2i32")
         },
         "shl_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vshls.v1i64")
         },
         "shl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vshlu.v1i64")
         },
         "shlq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vshls.v16i8")
         },
         "shlq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vshlu.v16i8")
         },
         "shlq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vshls.v8i16")
         },
         "shlq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vshlu.v8i16")
         },
         "shlq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vshls.v4i32")
         },
         "shlq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vshlu.v4i32")
         },
         "shlq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vshls.v2i64")
         },
         "shlq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vshlu.v2i64")
         },
         "qshl_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vqshls.v8i8")
         },
         "qshl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vqshlu.v8i8")
         },
         "qshl_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vqshls.v4i16")
         },
         "qshl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vqshlu.v4i16")
         },
         "qshl_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vqshls.v2i32")
         },
         "qshl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vqshlu.v2i32")
         },
         "qshl_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vqshls.v1i64")
         },
         "qshl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vqshlu.v1i64")
         },
         "qshlq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vqshls.v16i8")
         },
         "qshlq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vqshlu.v16i8")
         },
         "qshlq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vqshls.v8i16")
         },
         "qshlq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vqshlu.v8i16")
         },
         "qshlq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vqshls.v4i32")
         },
         "qshlq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vqshlu.v4i32")
         },
         "qshlq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vqshls.v2i64")
         },
         "qshlq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vqshlu.v2i64")
         },
         "rshl_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vrshls.v8i8")
         },
         "rshl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vrshlu.v8i8")
         },
         "rshl_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vrshls.v4i16")
         },
         "rshl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vrshlu.v4i16")
         },
         "rshl_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vrshls.v2i32")
         },
         "rshl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vrshlu.v2i32")
         },
         "rshl_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vrshls.v1i64")
         },
         "rshl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vrshlu.v1i64")
         },
         "rshlq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vrshls.v16i8")
         },
         "rshlq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vrshlu.v16i8")
         },
         "rshlq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vrshls.v8i16")
         },
         "rshlq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vrshlu.v8i16")
         },
         "rshlq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vrshls.v4i32")
         },
         "rshlq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vrshlu.v4i32")
         },
         "rshlq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vrshls.v2i64")
         },
         "rshlq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vrshlu.v2i64")
         },
         "qrshl_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vqrshls.v8i8")
         },
         "qrshl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vqrshlu.v8i8")
         },
         "qrshl_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vqrshls.v4i16")
         },
         "qrshl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vqrshlu.v4i16")
         },
         "qrshl_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vqrshls.v2i32")
         },
         "qrshl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vqrshlu.v2i32")
         },
         "qrshl_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vqrshls.v1i64")
         },
         "qrshl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vqrshlu.v1i64")
         },
         "qrshlq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vqrshls.v16i8")
         },
         "qrshlq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vqrshlu.v16i8")
         },
         "qrshlq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vqrshls.v8i16")
         },
         "qrshlq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vqrshlu.v8i16")
         },
         "qrshlq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vqrshls.v4i32")
         },
         "qrshlq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vqrshlu.v4i32")
         },
         "qrshlq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vqrshls.v2i64")
         },
         "qrshlq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vqrshlu.v2i64")
         },
         "qshrun_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vsqshrun.v8i8")
         },
         "qshrun_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vsqshrun.v4i16")
         },
         "qshrun_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vsqshrun.v2i32")
         },
         "qrshrun_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vsqrshrun.v8i8")
         },
         "qrshrun_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vsqrshrun.v4i16")
         },
         "qrshrun_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vsqrshrun.v2i32")
         },
         "qshrn_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vqshrns.v8i8")
         },
         "qshrn_n_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), u(32)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U32]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vqshrnu.v8i8")
         },
         "qshrn_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vqshrns.v4i16")
         },
         "qshrn_n_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), u(32)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vqshrnu.v4i16")
         },
         "qshrn_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vqshrns.v2i32")
         },
         "qshrn_n_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), u(32)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U32]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vqshrnu.v2i32")
         },
         "rshrn_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vrshrn.v8i8")
         },
         "rshrn_n_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), u(32)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U32]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vrshrn.v8i8")
         },
         "rshrn_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vrshrn.v4i16")
         },
         "rshrn_n_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), u(32)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vrshrn.v4i16")
         },
         "rshrn_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vrshrn.v2i32")
         },
         "rshrn_n_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), u(32)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U32]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vrshrn.v2i32")
         },
         "qrshrn_n_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), u(32)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::U32]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vqrshrns.v8i8")
         },
         "qrshrn_n_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), u(32)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U32]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vqrshrnu.v8i8")
         },
         "qrshrn_n_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), u(32)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::U32]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vqrshrns.v4i16")
         },
         "qrshrn_n_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), u(32)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vqrshrnu.v4i16")
         },
         "qrshrn_n_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), u(32)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::U32]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vqrshrns.v2i32")
         },
         "qrshrn_n_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), u(32)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U32]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vqrshrnu.v2i32")
         },
         "sri_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vvsri.v8i8")
         },
         "sri_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vvsri.v8i8")
         },
         "sri_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vvsri.v4i16")
         },
         "sri_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vvsri.v4i16")
         },
         "sri_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vvsri.v2i32")
         },
         "sri_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vvsri.v2i32")
         },
         "sri_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vvsri.v1i64")
         },
         "sri_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vvsri.v1i64")
         },
         "sriq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vvsri.v16i8")
         },
         "sriq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vvsri.v16i8")
         },
         "sriq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vvsri.v8i16")
         },
         "sriq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vvsri.v8i16")
         },
         "sriq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vvsri.v4i32")
         },
         "sriq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vvsri.v4i32")
         },
         "sriq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vvsri.v2i64")
         },
         "sriq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vvsri.v2i64")
         },
         "sli_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vvsli.v8i8")
         },
         "sli_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vvsli.v8i8")
         },
         "sli_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vvsli.v4i16")
         },
         "sli_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vvsli.v4i16")
         },
         "sli_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vvsli.v2i32")
         },
         "sli_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vvsli.v2i32")
         },
         "sli_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vvsli.v1i64")
         },
         "sli_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vvsli.v1i64")
         },
         "sliq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vvsli.v16i8")
         },
         "sliq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vvsli.v16i8")
         },
         "sliq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vvsli.v8i16")
         },
         "sliq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vvsli.v8i16")
         },
         "sliq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vvsli.v4i32")
         },
         "sliq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vvsli.v4i32")
         },
         "sliq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vvsli.v2i64")
         },
         "sliq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vvsli.v2i64")
         },
         "vqmovn_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vqxtns.v8i8")
         },
         "vqmovn_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vqxtnu.v8i8")
         },
         "vqmovn_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vqxtns.v4i16")
         },
         "vqmovn_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vqxtnu.v4i16")
         },
         "vqmovn_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I64x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vqxtns.v2i32")
         },
         "vqmovn_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U64x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vqxtnu.v2i32")
         },
         "abs_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vabs.v8i8")
         },
         "abs_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vabs.v4i16")
         },
         "abs_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vabs.v2i32")
         },
         "absq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vabs.v16i8")
         },
         "absq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vabs.v8i16")
         },
         "absq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vabs.v4i32")
         },
         "abs_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.fabs.v2f32")
         },
         "absq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.fabs.v4f32")
         },
         "qabs_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vsqabs.v8i8")
         },
         "qabs_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vsqabs.v4i16")
         },
         "qabs_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vsqabs.v2i32")
         },
         "qabsq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vsqabs.v16i8")
         },
         "qabsq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vsqabs.v8i16")
         },
         "qabsq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vsqabs.v4i32")
         },
         "qneg_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vsqneg.v8i8")
         },
         "qneg_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vsqneg.v4i16")
         },
         "qneg_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vsqneg.v2i32")
         },
         "qnegq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vsqneg.v16i8")
         },
         "qnegq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vsqneg.v8i16")
         },
         "qnegq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vsqneg.v4i32")
         },
         "clz_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.ctlz.v8i8")
         },
         "clz_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.ctlz.v8i8")
         },
         "clz_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.ctlz.v4i16")
         },
         "clz_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.ctlz.v4i16")
         },
         "clz_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.ctlz.v2i32")
         },
         "clz_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.ctlz.v2i32")
         },
         "clzq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.ctlz.v16i8")
         },
         "clzq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.ctlz.v16i8")
         },
         "clzq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.ctlz.v8i16")
         },
         "clzq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.ctlz.v8i16")
         },
         "clzq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.ctlz.v4i32")
         },
         "clzq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.ctlz.v4i32")
         },
         "cls_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vcls.v8i8")
         },
         "cls_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vcls.v8i8")
         },
         "cls_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vcls.v4i16")
         },
         "cls_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vcls.v4i16")
         },
         "cls_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vcls.v2i32")
         },
         "cls_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vcls.v2i32")
         },
         "clsq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vcls.v16i8")
         },
         "clsq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vcls.v16i8")
         },
         "clsq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vcls.v8i16")
         },
         "clsq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vcls.v8i16")
         },
         "clsq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vcls.v4i32")
         },
         "clsq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vcls.v4i32")
         },
         "cnt_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.ctpop.v8i8")
         },
         "cnt_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.ctpop.v8i8")
         },
         "cntq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.ctpop.v16i8")
         },
         "cntq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.ctpop.v16i8")
         },
         "recpe_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vrecpe.v2i32")
         },
         "recpe_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vrecpe.v2f32")
         },
         "recpeq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vrecpe.v4i32")
         },
         "recpeq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.neon.vrecpe.v4f32")
         },
         "recps_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vfrecps.v2f32")
         },
         "recpsq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.neon.vfrecps.v4f32")
         },
         "sqrt_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.sqrt.v2f32")
         },
         "sqrtq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.sqrt.v4f32")
         },
         "rsqrte_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vrsqrte.v2i32")
         },
         "rsqrte_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vrsqrte.v2f32")
         },
         "rsqrteq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vrsqrte.v4i32")
         },
         "rsqrteq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.neon.vrsqrte.v4f32")
         },
         "rsqrts_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vrsqrts.v2f32")
         },
         "rsqrtsq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.neon.vrsqrts.v4f32")
         },
         "bsl_s8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vbsl.v8i8")
         },
         "bsl_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vbsl.v8i8")
         },
         "bsl_s16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vbsl.v4i16")
         },
         "bsl_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vbsl.v4i16")
         },
         "bsl_s32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vbsl.v2i32")
         },
         "bsl_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vbsl.v2i32")
         },
         "bsl_s64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(i(64), 1)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::I64x1]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vbsl.v1i64")
         },
         "bsl_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(64), 1)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U64x1]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vbsl.v1i64")
         },
         "bslq_s8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vbsl.v16i8")
         },
         "bslq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vbsl.v16i8")
         },
         "bslq_s16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vbsl.v8i16")
         },
         "bslq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vbsl.v8i16")
         },
         "bslq_s32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vbsl.v4i32")
         },
         "bslq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vbsl.v4i32")
         },
         "bslq_s64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vbsl.v2i64")
         },
         "bslq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vbsl.v2i64")
         },
         "padd_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vpadd.v8i8")
         },
         "padd_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vpadd.v8i8")
         },
         "padd_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vpadd.v4i16")
         },
         "padd_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vpadd.v4i16")
         },
         "padd_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vpadd.v2i32")
         },
         "padd_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vpadd.v2i32")
         },
         "padd_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vpadd.v2f32")
         },
         "paddl_s16" => Intrinsic {
-            inputs: vec![v(i(8), 8)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x8]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vpaddls.v4i16.v8i8")
         },
         "paddl_u16" => Intrinsic {
-            inputs: vec![v(u(8), 8)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x8]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vpaddlu.v4i16.v8i8")
         },
         "paddl_s32" => Intrinsic {
-            inputs: vec![v(i(16), 4)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x4]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vpaddls.v2i32.v4i16")
         },
         "paddl_u32" => Intrinsic {
-            inputs: vec![v(u(16), 4)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x4]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vpaddlu.v2i32.v4i16")
         },
         "paddl_s64" => Intrinsic {
-            inputs: vec![v(i(32), 2)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x2]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vpaddls.v1i64.v2i32")
         },
         "paddl_u64" => Intrinsic {
-            inputs: vec![v(u(32), 2)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x2]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vpaddlu.v1i64.v2i32")
         },
         "paddlq_s16" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vpaddls.v8i16.v16i8")
         },
         "paddlq_u16" => Intrinsic {
-            inputs: vec![v(u(8), 16)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U8x16]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vpaddlu.v8i16.v16i8")
         },
         "paddlq_s32" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vpaddls.v4i32.v8i16")
         },
         "paddlq_u32" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vpaddlu.v4i32.v8i16")
         },
         "paddlq_s64" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vpaddls.v2i64.v4i32")
         },
         "paddlq_u64" => Intrinsic {
-            inputs: vec![v(u(32), 4)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U32x4]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vpaddlu.v2i64.v4i32")
         },
         "padal_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(8), 8)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I8x8]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vpadals.v4i16.v4i16")
         },
         "padal_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(8), 8)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U8x8]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vpadalu.v4i16.v4i16")
         },
         "padal_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(16), 4)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I16x4]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vpadals.v2i32.v2i32")
         },
         "padal_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(16), 4)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U16x4]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vpadalu.v2i32.v2i32")
         },
         "padal_s64" => Intrinsic {
-            inputs: vec![v(i(64), 1), v(i(32), 2)],
-            output: v(i(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x1, &::I32x2]; &INPUTS },
+            output: &::I64x1,
             definition: Named("llvm.neon.vpadals.v1i64.v1i64")
         },
         "padal_u64" => Intrinsic {
-            inputs: vec![v(u(64), 1), v(u(32), 2)],
-            output: v(u(64), 1),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x1, &::U32x2]; &INPUTS },
+            output: &::U64x1,
             definition: Named("llvm.neon.vpadalu.v1i64.v1i64")
         },
         "padalq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(8), 16)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I8x16]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vpadals.v8i16.v8i16")
         },
         "padalq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(8), 16)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U8x16]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vpadalu.v8i16.v8i16")
         },
         "padalq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(16), 8)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I16x8]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vpadals.v4i32.v4i32")
         },
         "padalq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(16), 8)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U16x8]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vpadalu.v4i32.v4i32")
         },
         "padalq_s64" => Intrinsic {
-            inputs: vec![v(i(64), 2), v(i(32), 4)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I64x2, &::I32x4]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.neon.vpadals.v2i64.v2i64")
         },
         "padalq_u64" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(32), 4)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U32x4]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.neon.vpadalu.v2i64.v2i64")
         },
         "pmax_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vpmaxs.v8i8")
         },
         "pmax_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vpmaxu.v8i8")
         },
         "pmax_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vpmaxs.v4i16")
         },
         "pmax_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vpmaxu.v4i16")
         },
         "pmax_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vpmaxs.v2i32")
         },
         "pmax_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vpmaxu.v2i32")
         },
         "pmax_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vpmaxf.v2f32")
         },
         "pmin_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vpmins.v8i8")
         },
         "pmin_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vpminu.v8i8")
         },
         "pmin_s16" => Intrinsic {
-            inputs: vec![v(i(16), 4), v(i(16), 4)],
-            output: v(i(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x4, &::I16x4]; &INPUTS },
+            output: &::I16x4,
             definition: Named("llvm.neon.vpmins.v4i16")
         },
         "pmin_u16" => Intrinsic {
-            inputs: vec![v(u(16), 4), v(u(16), 4)],
-            output: v(u(16), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x4, &::U16x4]; &INPUTS },
+            output: &::U16x4,
             definition: Named("llvm.neon.vpminu.v4i16")
         },
         "pmin_s32" => Intrinsic {
-            inputs: vec![v(i(32), 2), v(i(32), 2)],
-            output: v(i(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x2, &::I32x2]; &INPUTS },
+            output: &::I32x2,
             definition: Named("llvm.neon.vpmins.v2i32")
         },
         "pmin_u32" => Intrinsic {
-            inputs: vec![v(u(32), 2), v(u(32), 2)],
-            output: v(u(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x2, &::U32x2]; &INPUTS },
+            output: &::U32x2,
             definition: Named("llvm.neon.vpminu.v2i32")
         },
         "pmin_f32" => Intrinsic {
-            inputs: vec![v(f(32), 2), v(f(32), 2)],
-            output: v(f(32), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x2, &::F32x2]; &INPUTS },
+            output: &::F32x2,
             definition: Named("llvm.neon.vpminf.v2f32")
         },
         "pminq_s8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.neon.vpmins.v16i8")
         },
         "pminq_u8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.neon.vpminu.v16i8")
         },
         "pminq_s16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.neon.vpmins.v8i16")
         },
         "pminq_u16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.neon.vpminu.v8i16")
         },
         "pminq_s32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.neon.vpmins.v4i32")
         },
         "pminq_u32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.neon.vpminu.v4i32")
         },
         "pminq_f32" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.neon.vpminf.v4f32")
         },
         "tbl1_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x8, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vtbl1")
         },
         "tbl1_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vtbl1")
         },
         "tbx1_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), v(i(8), 8), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x8, &::I8x8, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vtbx1")
         },
         "tbx1_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), v(u(8), 8), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x8, &::U8x8, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vtbx1")
         },
         "tbl2_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 8), v(i(8), 8)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vtbl2")
         },
         "tbl2_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 8), v(u(8), 8)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vtbl2")
         },
         "tbx2_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 8), v(i(8), 8)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::I8x8, &::I8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vtbx2")
         },
         "tbx2_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 8), v(u(8), 8)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 2] = [&::U8x8, &::U8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vtbx2")
         },
         "tbl3_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 8), v(i(8), 8), v(i(8), 8)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::I8x8, &::I8x8, &::I8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vtbl3")
         },
         "tbl3_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 8), v(u(8), 8), v(u(8), 8)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::U8x8, &::U8x8, &::U8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vtbl3")
         },
         "tbx3_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), agg(true, vec![v(i(8), 8), v(i(8), 8), v(i(8), 8)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x8, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::I8x8, &::I8x8, &::I8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vtbx3")
         },
         "tbx3_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), agg(true, vec![v(u(8), 8), v(u(8), 8), v(u(8), 8)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x8, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 3] = [&::U8x8, &::U8x8, &::U8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vtbx3")
         },
         "tbl4_s8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(i(8), 8), v(i(8), 8), v(i(8), 8), v(i(8), 8)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::I8x8, &::I8x8, &::I8x8, &::I8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vtbl4")
         },
         "tbl4_u8" => Intrinsic {
-            inputs: vec![agg(true, vec![v(u(8), 8), v(u(8), 8), v(u(8), 8), v(u(8), 8)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::U8x8, &::U8x8, &::U8x8, &::U8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vtbl4")
         },
         "tbx4_s8" => Intrinsic {
-            inputs: vec![v(i(8), 8), agg(true, vec![v(i(8), 8), v(i(8), 8), v(i(8), 8), v(i(8), 8)]), v(u(8), 8)],
-            output: v(i(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x8, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::I8x8, &::I8x8, &::I8x8, &::I8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::I8x8,
             definition: Named("llvm.neon.vtbx4")
         },
         "tbx4_u8" => Intrinsic {
-            inputs: vec![v(u(8), 8), agg(true, vec![v(u(8), 8), v(u(8), 8), v(u(8), 8), v(u(8), 8)]), v(u(8), 8)],
-            output: v(u(8), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x8, { static AGG: Type = Type::Aggregate(true, { static PARTS: [&'static Type; 4] = [&::U8x8, &::U8x8, &::U8x8, &::U8x8]; &PARTS }); &AGG }, &::U8x8]; &INPUTS },
+            output: &::U8x8,
             definition: Named("llvm.neon.vtbx4")
         },
         _ => return None,
index 41d5c1a50bc9213528dda3a695e831c095fb5768..53976308bdc1933adef14b71372b2058752be4bb 100644 (file)
@@ -14,6 +14,7 @@
 #![crate_type = "rlib"]
 #![feature(staged_api, rustc_private)]
 #![cfg_attr(not(stage0), deny(warnings))]
+#![allow(bad_style)]
 
 extern crate rustc_llvm as llvm;
 extern crate rustc;
@@ -21,8 +22,8 @@
 use rustc::middle::ty::TyCtxt;
 
 pub struct Intrinsic {
-    pub inputs: Vec<Type>,
-    pub output: Type,
+    pub inputs: &'static [&'static Type],
+    pub output: &'static Type,
 
     pub definition: IntrinsicDef,
 }
@@ -32,34 +33,69 @@ pub enum Type {
     Void,
     Integer(/* signed */ bool, u8, /* llvm width */ u8),
     Float(u8),
-    Pointer(Box<Type>, Option<Box<Type>>, /* const */ bool),
-    Vector(Box<Type>, Option<Box<Type>>, u8),
-    Aggregate(bool, Vec<Type>),
+    Pointer(&'static Type, Option<&'static Type>, /* const */ bool),
+    Vector(&'static Type, Option<&'static Type>, u8),
+    Aggregate(bool, &'static [&'static Type]),
 }
 
 pub enum IntrinsicDef {
     Named(&'static str),
 }
 
-fn i(width: u8) -> Type { Type::Integer(true, width, width) }
-fn i_(width: u8, llvm_width: u8) -> Type { Type::Integer(true, width, llvm_width) }
-fn u(width: u8) -> Type { Type::Integer(false, width, width) }
-#[allow(dead_code)]
-fn u_(width: u8, llvm_width: u8) -> Type { Type::Integer(false, width, llvm_width) }
-fn f(width: u8) -> Type { Type::Float(width) }
-fn v(x: Type, length: u8) -> Type { Type::Vector(Box::new(x), None, length) }
-fn v_(x: Type, bitcast: Type, length: u8) -> Type {
-    Type::Vector(Box::new(x), Some(Box::new(bitcast)), length)
-}
-fn agg(flatten: bool, types: Vec<Type>) -> Type {
-    Type::Aggregate(flatten, types)
-}
-fn p(const_: bool, elem: Type, llvm_elem: Option<Type>) -> Type {
-    Type::Pointer(Box::new(elem), llvm_elem.map(Box::new), const_)
-}
-fn void() -> Type {
-    Type::Void
-}
+static I8: Type = Type::Integer(true, 8, 8);
+static I16: Type = Type::Integer(true, 16, 16);
+static I32: Type = Type::Integer(true, 32, 32);
+static I64: Type = Type::Integer(true, 64, 64);
+static U8: Type = Type::Integer(false, 8, 8);
+static U16: Type = Type::Integer(false, 16, 16);
+static U32: Type = Type::Integer(false, 32, 32);
+static U64: Type = Type::Integer(false, 64, 64);
+static F32: Type = Type::Float(32);
+static F64: Type = Type::Float(64);
+
+static I32_8: Type = Type::Integer(true, 32, 8);
+
+static I8x8: Type = Type::Vector(&I8, None, 8);
+static U8x8: Type = Type::Vector(&U8, None, 8);
+static I8x16: Type = Type::Vector(&I8, None, 16);
+static U8x16: Type = Type::Vector(&U8, None, 16);
+static I8x32: Type = Type::Vector(&I8, None, 32);
+static U8x32: Type = Type::Vector(&U8, None, 32);
+
+static I16x4: Type = Type::Vector(&I16, None, 4);
+static U16x4: Type = Type::Vector(&U16, None, 4);
+static I16x8: Type = Type::Vector(&I16, None, 8);
+static U16x8: Type = Type::Vector(&U16, None, 8);
+static I16x16: Type = Type::Vector(&I16, None, 16);
+static U16x16: Type = Type::Vector(&U16, None, 16);
+
+static I32x2: Type = Type::Vector(&I32, None, 2);
+static U32x2: Type = Type::Vector(&U32, None, 2);
+static I32x4: Type = Type::Vector(&I32, None, 4);
+static U32x4: Type = Type::Vector(&U32, None, 4);
+static I32x8: Type = Type::Vector(&I32, None, 8);
+static U32x8: Type = Type::Vector(&U32, None, 8);
+
+static I64x1: Type = Type::Vector(&I64, None, 1);
+static U64x1: Type = Type::Vector(&U64, None, 1);
+static I64x2: Type = Type::Vector(&I64, None, 2);
+static U64x2: Type = Type::Vector(&U64, None, 2);
+static I64x4: Type = Type::Vector(&I64, None, 4);
+static U64x4: Type = Type::Vector(&U64, None, 4);
+
+static F32x2: Type = Type::Vector(&F32, None, 2);
+static F32x4: Type = Type::Vector(&F32, None, 4);
+static F32x8: Type = Type::Vector(&F32, None, 8);
+static F64x1: Type = Type::Vector(&F64, None, 1);
+static F64x2: Type = Type::Vector(&F64, None, 2);
+static F64x4: Type = Type::Vector(&F64, None, 4);
+
+static I32x4_F32: Type = Type::Vector(&I32, Some(&F32), 4);
+static I32x8_F32: Type = Type::Vector(&I32, Some(&F32), 8);
+static I64x2_F64: Type = Type::Vector(&I64, Some(&F64), 2);
+static I64x4_F64: Type = Type::Vector(&I64, Some(&F64), 4);
+
+static VOID: Type = Type::Void;
 
 mod x86;
 mod arm;
index c5d3e414c7cab491c7c2fec94f1492817be59065..eccdc77f33c9d84a8534ae6a9d50c4a48573acf6 100644 (file)
@@ -13,7 +13,7 @@
 
 #![allow(unused_imports)]
 
-use {Intrinsic, i, i_, u, u_, f, v, v_, agg, p, void};
+use {Intrinsic, Type};
 use IntrinsicDef::Named;
 use rustc::middle::ty::TyCtxt;
 
@@ -24,1278 +24,1278 @@ pub fn find<'tcx>(_tcx: &TyCtxt<'tcx>, name: &str) -> Option<Intrinsic> {
     if !name.starts_with("x86_mm") { return None }
     Some(match &name["x86_mm".len()..] {
         "_movemask_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse.movmsk.ps")
         },
         "_max_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.sse.max.ps")
         },
         "_min_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.sse.min.ps")
         },
         "_rsqrt_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.sse.rsqrt.ps")
         },
         "_rcp_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.sse.rcp.ps")
         },
         "_sqrt_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.sqrt.v4f32")
         },
         "_storeu_ps" => Intrinsic {
-            inputs: vec![p(false, f(32), Some(i(8))), v(f(32), 4)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::I8), false); &PTR }, &::F32x4]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.sse.storeu.ps")
         },
         "_adds_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.sse2.padds.b")
         },
         "_adds_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.x86.sse2.paddus.b")
         },
         "_adds_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.sse2.padds.w")
         },
         "_adds_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse2.paddus.w")
         },
         "_avg_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.x86.sse2.pavg.b")
         },
         "_avg_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse2.pavg.w")
         },
         "_lfence" => Intrinsic {
-            inputs: vec![],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 0] = []; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.sse2.lfence")
         },
         "_madd_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.sse2.pmadd.wd")
         },
         "_maskmoveu_si128" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16), p(false, u(8), None)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x16, &::U8x16, { static PTR: Type = Type::Pointer(&::U8, None, false); &PTR }]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.sse2.maskmov.dqu")
         },
         "_max_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.sse2.pmaxs.w")
         },
         "_max_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.x86.sse2.pmaxu.b")
         },
         "_max_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.sse2.max.pd")
         },
         "_mfence" => Intrinsic {
-            inputs: vec![],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 0] = []; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.sse2.fence")
         },
         "_min_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.sse2.pmins.w")
         },
         "_min_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.x86.sse2.pminu.b")
         },
         "_min_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.sse2.min.pd")
         },
         "_movemask_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse2.movmsk.pd")
         },
         "_movemask_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse2.pmovmskb.128")
         },
         "_mul_epu32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.x86.sse2.pmulu.dq")
         },
         "_mulhi_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.sse2.pmulh.w")
         },
         "_mulhi_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse2.pmulhu.w")
         },
         "_packs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.sse2.packsswb.128")
         },
         "_packs_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.sse2.packssdw.128")
         },
         "_packus_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.x86.sse2.packuswb.128")
         },
         "_sad_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U64x2,
             definition: Named("llvm.x86.sse2.psad.bw")
         },
         "_sfence" => Intrinsic {
-            inputs: vec![],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 0] = []; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.sse2.sfence")
         },
         "_sqrt_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.sqrt.v2f64")
         },
         "_storeu_pd" => Intrinsic {
-            inputs: vec![p(false, f(64), Some(u(8))), v(f(64), 2)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::U8), false); &PTR }, &::F64x2]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.sse2.storeu.pd")
         },
         "_storeu_si128" => Intrinsic {
-            inputs: vec![p(false, v(u(8), 16), Some(u(8))), v(u(8), 16)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::U8x16, Some(&::U8), false); &PTR }, &::U8x16]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.sse2.storeu.dq")
         },
         "_subs_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.sse2.psubs.b")
         },
         "_subs_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16)],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::U8x16]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.x86.sse2.psubus.b")
         },
         "_subs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.sse2.psubs.w")
         },
         "_subs_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse2.psubus.w")
         },
         "_addsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.sse3.addsub.ps")
         },
         "_addsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.sse3.addsub.pd")
         },
         "_hadd_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.sse3.hadd.ps")
         },
         "_hadd_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.sse3.hadd.pd")
         },
         "_hsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.sse3.hsub.ps")
         },
         "_hsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.sse3.hsub.pd")
         },
         "_lddqu_si128" => Intrinsic {
-            inputs: vec![p(true, v(u(8), 16), Some(i(8)))],
-            output: v(u(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::U8x16, Some(&::I8), true); &PTR }]; &INPUTS },
+            output: &::U8x16,
             definition: Named("llvm.x86.sse3.ldu.dq")
         },
         "_abs_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.ssse3.pabs.b.128")
         },
         "_abs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.ssse3.pabs.w.128")
         },
         "_abs_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.ssse3.pabs.d.128")
         },
         "_hadd_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.ssse3.phadd.w.128")
         },
         "_hadd_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.ssse3.phadd.d.128")
         },
         "_hadds_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.ssse3.phadd.sw.128")
         },
         "_hsub_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.ssse3.phsub.w.128")
         },
         "_hsub_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.ssse3.phsub.d.128")
         },
         "_hsubs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.ssse3.phsub.sw.128")
         },
         "_maddubs_epi16" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(i(8), 16)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x16, &::I8x16]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.ssse3.pmadd.ub.sw.128")
         },
         "_mulhrs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.ssse3.pmul.hr.sw.128")
         },
         "_shuffle_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.ssse3.pshuf.b.128")
         },
         "_sign_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.ssse3.psign.b.128")
         },
         "_sign_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 8), v(i(16), 8)],
-            output: v(i(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x8, &::I16x8]; &INPUTS },
+            output: &::I16x8,
             definition: Named("llvm.x86.ssse3.psign.w.128")
         },
         "_sign_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.ssse3.psign.d.128")
         },
         "_dp_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4), i_(32, 8)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::I32_8]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.sse41.dpps")
         },
         "_dp_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2), i_(32, 8)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::I32_8]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.sse41.dppd")
         },
         "_max_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.sse41.pmaxsb")
         },
         "_max_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse41.pmaxuw")
         },
         "_max_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.sse41.pmaxsd")
         },
         "_max_epu32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.x86.sse41.pmaxud")
         },
         "_min_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x16, &::I8x16]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.sse41.pminsb")
         },
         "_min_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 8), v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x8, &::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse41.pminuw")
         },
         "_min_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.sse41.pminsd")
         },
         "_min_epu32" => Intrinsic {
-            inputs: vec![v(u(32), 4), v(u(32), 4)],
-            output: v(u(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x4, &::U32x4]; &INPUTS },
+            output: &::U32x4,
             definition: Named("llvm.x86.sse41.pminud")
         },
         "_minpos_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::U16x8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse41.phminposuw")
         },
         "_mpsadbw_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 16), v(u(8), 16), i_(32, 8)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x16, &::U8x16, &::I32_8]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse41.mpsadbw")
         },
         "_mul_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.x86.sse41.pmuldq")
         },
         "_packus_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), v(i(32), 4)],
-            output: v(u(16), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x4, &::I32x4]; &INPUTS },
+            output: &::U16x8,
             definition: Named("llvm.x86.sse41.packusdw")
         },
         "_testc_si128" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse41.ptestc")
         },
         "_testnzc_si128" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse41.ptestnzc")
         },
         "_testz_si128" => Intrinsic {
-            inputs: vec![v(u(64), 2), v(u(64), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x2, &::U64x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse41.ptestz")
         },
         "_cmpestra" => Intrinsic {
-            inputs: vec![v(i(8), 16), i(32), v(i(8), 16), i(32), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I8x16, &::I32, &::I8x16, &::I32, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpestria128")
         },
         "_cmpestrc" => Intrinsic {
-            inputs: vec![v(i(8), 16), i(32), v(i(8), 16), i(32), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I8x16, &::I32, &::I8x16, &::I32, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpestric128")
         },
         "_cmpestri" => Intrinsic {
-            inputs: vec![v(i(8), 16), i(32), v(i(8), 16), i(32), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I8x16, &::I32, &::I8x16, &::I32, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpestri128")
         },
         "_cmpestrm" => Intrinsic {
-            inputs: vec![v(i(8), 16), i(32), v(i(8), 16), i(32), i_(32, 8)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I8x16, &::I32, &::I8x16, &::I32, &::I32_8]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.sse42.pcmpestrm128")
         },
         "_cmpestro" => Intrinsic {
-            inputs: vec![v(i(8), 16), i(32), v(i(8), 16), i(32), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I8x16, &::I32, &::I8x16, &::I32, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpestrio128")
         },
         "_cmpestrs" => Intrinsic {
-            inputs: vec![v(i(8), 16), i(32), v(i(8), 16), i(32), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I8x16, &::I32, &::I8x16, &::I32, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpestris128")
         },
         "_cmpestrz" => Intrinsic {
-            inputs: vec![v(i(8), 16), i(32), v(i(8), 16), i(32), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I8x16, &::I32, &::I8x16, &::I32, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpestriz128")
         },
         "_cmpistra" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpistria128")
         },
         "_cmpistrc" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpistric128")
         },
         "_cmpistri" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpistri128")
         },
         "_cmpistrm" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16), i_(32, 8)],
-            output: v(i(8), 16),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I32_8]; &INPUTS },
+            output: &::I8x16,
             definition: Named("llvm.x86.sse42.pcmpistrm128")
         },
         "_cmpistro" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpistrio128")
         },
         "_cmpistrs" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpistris128")
         },
         "_cmpistrz" => Intrinsic {
-            inputs: vec![v(i(8), 16), v(i(8), 16), i_(32, 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::I8x16, &::I8x16, &::I32_8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.sse42.pcmpistriz128")
         },
         "256_addsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.addsub.ps.256")
         },
         "256_addsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.addsub.pd.256")
         },
         "256_blendv_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.blendv.ps.256")
         },
         "256_blendv_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x4, &::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.blendv.pd.256")
         },
         "256_broadcast_ps" => Intrinsic {
-            inputs: vec![p(true, i(8), None)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, None, true); &PTR }]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.vbroadcastf128.ps.256")
         },
         "256_broadcast_pd" => Intrinsic {
-            inputs: vec![p(true, i(8), None)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [{ static PTR: Type = Type::Pointer(&::I8, None, true); &PTR }]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.vbroadcastf128.pd.256")
         },
         "256_cmp_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), i(8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::I8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.cmp.ps.256")
         },
         "256_cmp_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4), i(8)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x4, &::F64x4, &::I8]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.cmp.pd.256")
         },
         "256_cvtepi32_pd" => Intrinsic {
-            inputs: vec![v(i(32), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.cvtdq2.pd.256")
         },
         "256_cvtepi32_ps" => Intrinsic {
-            inputs: vec![v(i(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.cvtdq2.ps.256")
         },
         "256_cvtpd_epi32" => Intrinsic {
-            inputs: vec![v(f(64), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.avx.cvt.pd2dq.256")
         },
         "256_cvtpd_ps" => Intrinsic {
-            inputs: vec![v(f(64), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.avx.cvt.pd2.ps.256")
         },
         "256_cvtps_epi32" => Intrinsic {
-            inputs: vec![v(f(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx.cvt.ps2dq.256")
         },
         "256_cvtps_pd" => Intrinsic {
-            inputs: vec![v(f(32), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.cvt.ps2.pd.256")
         },
         "256_cvttpd_epi32" => Intrinsic {
-            inputs: vec![v(f(64), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.avx.cvtt.pd2dq.256")
         },
         "256_cvttps_epi32" => Intrinsic {
-            inputs: vec![v(f(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx.cvtt.ps2dq.256")
         },
         "256_dp_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), i_(32, 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::I32_8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.dp.ps.256")
         },
         "256_hadd_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.hadd.ps.256")
         },
         "256_hadd_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.hadd.pd.256")
         },
         "256_hsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.hsub.ps.256")
         },
         "256_hsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.hsub.pd.256")
         },
         "256_max_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.max.ps.256")
         },
         "256_max_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.max.pd.256")
         },
         "_maskload_ps" => Intrinsic {
-            inputs: vec![p(true, f(32), Some(i(8))), v_(i(32), f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::I8), true); &PTR }, &::I32x4_F32]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.avx.maskload.ps")
         },
         "_maskload_pd" => Intrinsic {
-            inputs: vec![p(true, f(64), Some(i(8))), v_(i(64), f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::I8), true); &PTR }, &::I64x2_F64]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.avx.maskload.pd")
         },
         "256_maskload_ps" => Intrinsic {
-            inputs: vec![p(true, f(32), Some(i(8))), v_(i(32), f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::I8), true); &PTR }, &::I32x8_F32]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.maskload.ps.256")
         },
         "256_maskload_pd" => Intrinsic {
-            inputs: vec![p(true, f(64), Some(i(8))), v_(i(64), f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::I8), true); &PTR }, &::I64x4_F64]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.maskload.pd.256")
         },
         "_maskstore_ps" => Intrinsic {
-            inputs: vec![p(false, f(32), Some(i(8))), v_(i(32), f(32), 4), v(f(32), 4)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::I8), false); &PTR }, &::I32x4_F32, &::F32x4]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.maskstore.ps")
         },
         "_maskstore_pd" => Intrinsic {
-            inputs: vec![p(false, f(64), Some(i(8))), v_(i(64), f(64), 2), v(f(64), 2)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::I8), false); &PTR }, &::I64x2_F64, &::F64x2]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.maskstore.pd")
         },
         "256_maskstore_ps" => Intrinsic {
-            inputs: vec![p(false, f(32), Some(i(8))), v_(i(32), f(32), 8), v(f(32), 8)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [{ static PTR: Type = Type::Pointer(&::F32, Some(&::I8), false); &PTR }, &::I32x8_F32, &::F32x8]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.maskstore.ps.256")
         },
         "256_maskstore_pd" => Intrinsic {
-            inputs: vec![p(false, f(64), Some(i(8))), v_(i(64), f(64), 4), v(f(64), 4)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [{ static PTR: Type = Type::Pointer(&::F64, Some(&::I8), false); &PTR }, &::I64x4_F64, &::F64x4]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.maskstore.pd.256")
         },
         "256_min_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.min.ps.256")
         },
         "256_min_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.min.pd.256")
         },
         "256_movemask_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.movmsk.ps.256")
         },
         "256_movemask_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.movmsk.pd.256")
         },
         "_permutevar_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(i(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::I32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.avx.vpermilvar.ps")
         },
         "_permutevar_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(i(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::I64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.avx.vpermilvar.pd")
         },
         "256_permutevar_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(i(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::I32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.vpermilvar.ps.256")
         },
         "256_permutevar_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(i(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::I64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx.vpermilvar.pd.256")
         },
         "256_rcp_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.rcp.ps.256")
         },
         "256_rsqrt_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx.rsqrt.ps.256")
         },
         "256_storeu_ps" => Intrinsic {
-            inputs: vec![p(false, v(f(32), 8), Some(u(8))), v(f(32), 8)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::F32x8, Some(&::U8), false); &PTR }, &::F32x8]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.storeu.ps.256")
         },
         "256_storeu_pd" => Intrinsic {
-            inputs: vec![p(false, v(f(64), 4), Some(u(8))), v(f(64), 4)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::F64x4, Some(&::U8), false); &PTR }, &::F64x4]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.storeu.ps.256")
         },
         "256_storeu_si256" => Intrinsic {
-            inputs: vec![p(false, v(u(8), 32), Some(u(8))), v(u(8), 32)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::U8x32, Some(&::U8), false); &PTR }, &::U8x32]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.storeu.dq.256")
         },
         "256_sqrt_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.sqrt.v8f32")
         },
         "256_sqrt_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.sqrt.v4f64")
         },
         "_testc_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestc.ps")
         },
         "256_testc_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::F32x8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestc.ps.256")
         },
         "_testc_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestc.pd")
         },
         "256_testc_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::F64x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestc.pd.256")
         },
         "256_testc_si256" => Intrinsic {
-            inputs: vec![v(u(64), 4), v(u(64), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x4, &::U64x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.ptestc.256")
         },
         "_testnzc_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestnzc.ps")
         },
         "256_testnzc_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::F32x8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestnzc.ps.256")
         },
         "_testnzc_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestnzc.pd")
         },
         "256_testnzc_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::F64x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestnzc.pd.256")
         },
         "256_testnzc_si256" => Intrinsic {
-            inputs: vec![v(u(64), 4), v(u(64), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x4, &::U64x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.ptestnzc.256")
         },
         "_testz_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x4, &::F32x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestz.ps")
         },
         "256_testz_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::F32x8]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestz.ps.256")
         },
         "_testz_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x2, &::F64x2]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestz.pd")
         },
         "256_testz_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F64x4, &::F64x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.vtestz.pd.256")
         },
         "256_testz_si256" => Intrinsic {
-            inputs: vec![v(u(64), 4), v(u(64), 4)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U64x4, &::U64x4]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx.ptestz.256")
         },
         "256_zeroall" => Intrinsic {
-            inputs: vec![],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 0] = []; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.vzeroall")
         },
         "256_zeroupper" => Intrinsic {
-            inputs: vec![],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 0] = []; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx.vzeroupper")
         },
         "256_abs_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 32)],
-            output: v(i(8), 32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x32]; &INPUTS },
+            output: &::I8x32,
             definition: Named("llvm.x86.avx2.pabs.b")
         },
         "256_abs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.pabs.w")
         },
         "256_abs_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.pabs.d")
         },
         "256_adds_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 32), v(i(8), 32)],
-            output: v(i(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x32, &::I8x32]; &INPUTS },
+            output: &::I8x32,
             definition: Named("llvm.x86.avx2.padds.b")
         },
         "256_adds_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 32), v(u(8), 32)],
-            output: v(u(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x32, &::U8x32]; &INPUTS },
+            output: &::U8x32,
             definition: Named("llvm.x86.avx2.paddus.b")
         },
         "256_adds_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.padds.w")
         },
         "256_adds_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 16), v(u(16), 16)],
-            output: v(u(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x16, &::U16x16]; &INPUTS },
+            output: &::U16x16,
             definition: Named("llvm.x86.avx2.paddus.w")
         },
         "256_avg_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 32), v(u(8), 32)],
-            output: v(u(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x32, &::U8x32]; &INPUTS },
+            output: &::U8x32,
             definition: Named("llvm.x86.avx2.pavg.b")
         },
         "256_avg_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 16), v(u(16), 16)],
-            output: v(u(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x16, &::U16x16]; &INPUTS },
+            output: &::U16x16,
             definition: Named("llvm.x86.avx2.pavg.w")
         },
         "256_hadd_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.phadd.w")
         },
         "256_hadd_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.phadd.d")
         },
         "256_hadds_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.phadd.sw")
         },
         "256_hsub_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.phsub.w")
         },
         "256_hsub_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.phsub.d")
         },
         "256_hsubs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.phsub.sw")
         },
         "256_madd_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.pmadd.wd")
         },
         "256_maddubs_epi16" => Intrinsic {
-            inputs: vec![v(i(8), 32), v(i(8), 32)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x32, &::I8x32]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.pmadd.ub.sw")
         },
         "_mask_i32gather_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), p(true, i(32), Some(i(8))), v(i(32), 4), v(i(32), 4), i_(32, 8)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I32x4, { static PTR: Type = Type::Pointer(&::I32, Some(&::I8), true); &PTR }, &::I32x4, &::I32x4, &::I32_8]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.avx2.gather.d.d")
         },
         "_mask_i32gather_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), p(true, f(32), Some(i(8))), v(i(32), 4), v_(i(32), f(32), 4), i_(32, 8)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::F32x4, { static PTR: Type = Type::Pointer(&::F32, Some(&::I8), true); &PTR }, &::I32x4, &::I32x4_F32, &::I32_8]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.avx2.gather.d.ps")
         },
         "256_mask_i32gather_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), p(true, i(32), Some(i(8))), v(i(32), 8), v(i(32), 8), i_(32, 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I32x8, { static PTR: Type = Type::Pointer(&::I32, Some(&::I8), true); &PTR }, &::I32x8, &::I32x8, &::I32_8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.gather.d.d.256")
         },
         "256_mask_i32gather_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), p(true, f(32), Some(i(8))), v(i(32), 8), v_(i(32), f(32), 8), i_(32, 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::F32x8, { static PTR: Type = Type::Pointer(&::F32, Some(&::I8), true); &PTR }, &::I32x8, &::I32x8_F32, &::I32_8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx2.gather.d.ps.256")
         },
         "_mask_i32gather_epi64" => Intrinsic {
-            inputs: vec![v(i(64), 2), p(true, i(64), Some(i(8))), v(i(32), 4), v(i(64), 2), i_(32, 8)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I64x2, { static PTR: Type = Type::Pointer(&::I64, Some(&::I8), true); &PTR }, &::I32x4, &::I64x2, &::I32_8]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.x86.avx2.gather.d.q")
         },
         "_mask_i32gather_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), p(true, f(64), Some(i(8))), v(i(32), 4), v_(i(64), f(64), 2), i_(32, 8)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::F64x2, { static PTR: Type = Type::Pointer(&::F64, Some(&::I8), true); &PTR }, &::I32x4, &::I64x2_F64, &::I32_8]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.avx2.gather.d.pd")
         },
         "256_mask_i32gather_epi64" => Intrinsic {
-            inputs: vec![v(i(64), 4), p(true, i(64), Some(i(8))), v(i(32), 4), v(i(64), 4), i_(32, 8)],
-            output: v(i(64), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I64x4, { static PTR: Type = Type::Pointer(&::I64, Some(&::I8), true); &PTR }, &::I32x4, &::I64x4, &::I32_8]; &INPUTS },
+            output: &::I64x4,
             definition: Named("llvm.x86.avx2.gather.d.q.256")
         },
         "256_mask_i32gather_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), p(true, f(64), Some(i(8))), v(i(32), 4), v_(i(64), f(64), 4), i_(32, 8)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::F64x4, { static PTR: Type = Type::Pointer(&::F64, Some(&::I8), true); &PTR }, &::I32x4, &::I64x4_F64, &::I32_8]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx2.gather.d.pd.256")
         },
         "_mask_i64gather_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), p(true, i(32), Some(i(8))), v(i(64), 2), v(i(32), 4), i_(32, 8)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I32x4, { static PTR: Type = Type::Pointer(&::I32, Some(&::I8), true); &PTR }, &::I64x2, &::I32x4, &::I32_8]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.avx2.gather.q.d")
         },
         "_mask_i64gather_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), p(true, f(32), Some(i(8))), v(i(64), 2), v_(i(32), f(32), 4), i_(32, 8)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::F32x4, { static PTR: Type = Type::Pointer(&::F32, Some(&::I8), true); &PTR }, &::I64x2, &::I32x4_F32, &::I32_8]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.avx2.gather.q.ps")
         },
         "256_mask_i64gather_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 4), p(true, i(32), Some(i(8))), v(i(64), 4), v(i(32), 4), i_(32, 8)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I32x4, { static PTR: Type = Type::Pointer(&::I32, Some(&::I8), true); &PTR }, &::I64x4, &::I32x4, &::I32_8]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.avx2.gather.q.d")
         },
         "256_mask_i64gather_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), p(true, f(32), Some(i(8))), v(i(64), 4), v_(i(32), f(32), 4), i_(32, 8)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::F32x4, { static PTR: Type = Type::Pointer(&::F32, Some(&::I8), true); &PTR }, &::I64x4, &::I32x4_F32, &::I32_8]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.avx2.gather.q.ps")
         },
         "_mask_i64gather_epi64" => Intrinsic {
-            inputs: vec![v(i(64), 2), p(true, i(64), Some(i(8))), v(i(64), 2), v(i(64), 2), i_(32, 8)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I64x2, { static PTR: Type = Type::Pointer(&::I64, Some(&::I8), true); &PTR }, &::I64x2, &::I64x2, &::I32_8]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.x86.avx2.gather.q.q")
         },
         "_mask_i64gather_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), p(true, f(64), Some(i(8))), v(i(64), 2), v_(i(64), f(64), 2), i_(32, 8)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::F64x2, { static PTR: Type = Type::Pointer(&::F64, Some(&::I8), true); &PTR }, &::I64x2, &::I64x2_F64, &::I32_8]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.avx2.gather.q.pd")
         },
         "256_mask_i64gather_epi64" => Intrinsic {
-            inputs: vec![v(i(64), 4), p(true, i(64), Some(i(8))), v(i(64), 4), v(i(64), 4), i_(32, 8)],
-            output: v(i(64), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::I64x4, { static PTR: Type = Type::Pointer(&::I64, Some(&::I8), true); &PTR }, &::I64x4, &::I64x4, &::I32_8]; &INPUTS },
+            output: &::I64x4,
             definition: Named("llvm.x86.avx2.gather.q.q.256")
         },
         "256_mask_i64gather_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), p(true, f(64), Some(i(8))), v(i(64), 4), v_(i(64), f(64), 4), i_(32, 8)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 5] = [&::F64x4, { static PTR: Type = Type::Pointer(&::F64, Some(&::I8), true); &PTR }, &::I64x4, &::I64x4_F64, &::I32_8]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.avx2.gather.q.pd.256")
         },
         "_maskload_epi32" => Intrinsic {
-            inputs: vec![p(true, v(i(32), 4), Some(i(8))), v(i(32), 4)],
-            output: v(i(32), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::I32x4, Some(&::I8), true); &PTR }, &::I32x4]; &INPUTS },
+            output: &::I32x4,
             definition: Named("llvm.x86.avx2.maskload.d")
         },
         "_maskload_epi64" => Intrinsic {
-            inputs: vec![p(true, v(i(64), 2), Some(i(8))), v(i(64), 2)],
-            output: v(i(64), 2),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::I64x2, Some(&::I8), true); &PTR }, &::I64x2]; &INPUTS },
+            output: &::I64x2,
             definition: Named("llvm.x86.avx2.maskload.q")
         },
         "256_maskload_epi32" => Intrinsic {
-            inputs: vec![p(true, v(i(32), 8), Some(i(8))), v(i(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::I32x8, Some(&::I8), true); &PTR }, &::I32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.maskload.d.256")
         },
         "256_maskload_epi64" => Intrinsic {
-            inputs: vec![p(true, v(i(64), 4), Some(i(8))), v(i(64), 4)],
-            output: v(i(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [{ static PTR: Type = Type::Pointer(&::I64x4, Some(&::I8), true); &PTR }, &::I64x4]; &INPUTS },
+            output: &::I64x4,
             definition: Named("llvm.x86.avx2.maskload.q.256")
         },
         "_maskstore_epi32" => Intrinsic {
-            inputs: vec![p(false, i(32), Some(i(8))), v(i(32), 4), v(i(32), 4)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [{ static PTR: Type = Type::Pointer(&::I32, Some(&::I8), false); &PTR }, &::I32x4, &::I32x4]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx2.maskstore.d")
         },
         "_maskstore_epi64" => Intrinsic {
-            inputs: vec![p(false, i(64), Some(i(8))), v(i(64), 2), v(i(64), 2)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [{ static PTR: Type = Type::Pointer(&::I64, Some(&::I8), false); &PTR }, &::I64x2, &::I64x2]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx2.maskstore.q")
         },
         "256_maskstore_epi32" => Intrinsic {
-            inputs: vec![p(false, i(32), Some(i(8))), v(i(32), 8), v(i(32), 8)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [{ static PTR: Type = Type::Pointer(&::I32, Some(&::I8), false); &PTR }, &::I32x8, &::I32x8]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx2.maskstore.d.256")
         },
         "256_maskstore_epi64" => Intrinsic {
-            inputs: vec![p(false, i(64), Some(i(8))), v(i(64), 4), v(i(64), 4)],
-            output: void(),
+            inputs: { static INPUTS: [&'static Type; 3] = [{ static PTR: Type = Type::Pointer(&::I64, Some(&::I8), false); &PTR }, &::I64x4, &::I64x4]; &INPUTS },
+            output: &::VOID,
             definition: Named("llvm.x86.avx2.maskstore.q.256")
         },
         "256_max_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 32), v(i(8), 32)],
-            output: v(i(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x32, &::I8x32]; &INPUTS },
+            output: &::I8x32,
             definition: Named("llvm.x86.avx2.pmaxs.b")
         },
         "256_max_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 32), v(u(8), 32)],
-            output: v(u(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x32, &::U8x32]; &INPUTS },
+            output: &::U8x32,
             definition: Named("llvm.x86.avx2.pmaxu.b")
         },
         "256_max_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.pmaxs.w")
         },
         "256_max_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 16), v(u(16), 16)],
-            output: v(u(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x16, &::U16x16]; &INPUTS },
+            output: &::U16x16,
             definition: Named("llvm.x86.avx2.pmaxu.w")
         },
         "256_max_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.pmaxs.d")
         },
         "256_max_epu32" => Intrinsic {
-            inputs: vec![v(u(32), 8), v(u(32), 8)],
-            output: v(u(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x8, &::U32x8]; &INPUTS },
+            output: &::U32x8,
             definition: Named("llvm.x86.avx2.pmaxu.d")
         },
         "256_min_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 32), v(i(8), 32)],
-            output: v(i(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x32, &::I8x32]; &INPUTS },
+            output: &::I8x32,
             definition: Named("llvm.x86.avx2.pmins.b")
         },
         "256_min_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 32), v(u(8), 32)],
-            output: v(u(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x32, &::U8x32]; &INPUTS },
+            output: &::U8x32,
             definition: Named("llvm.x86.avx2.pminu.b")
         },
         "256_min_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.pmins.w")
         },
         "256_min_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 16), v(u(16), 16)],
-            output: v(u(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x16, &::U16x16]; &INPUTS },
+            output: &::U16x16,
             definition: Named("llvm.x86.avx2.pminu.w")
         },
         "256_min_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.pmins.d")
         },
         "256_min_epu32" => Intrinsic {
-            inputs: vec![v(u(32), 8), v(u(32), 8)],
-            output: v(u(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x8, &::U32x8]; &INPUTS },
+            output: &::U32x8,
             definition: Named("llvm.x86.avx2.pminu.d")
         },
         "256_movemask_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 32)],
-            output: i(32),
+            inputs: { static INPUTS: [&'static Type; 1] = [&::I8x32]; &INPUTS },
+            output: &::I32,
             definition: Named("llvm.x86.avx2.pmovmskb")
         },
         "256_mpsadbw_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 32), v(u(8), 32), i_(32, 8)],
-            output: v(u(16), 16),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::U8x32, &::U8x32, &::I32_8]; &INPUTS },
+            output: &::U16x16,
             definition: Named("llvm.x86.avx2.mpsadbw")
         },
         "256_mul_epi64" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(i(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::I64x4,
             definition: Named("llvm.x86.avx2.pmulq.dq")
         },
         "256_mul_epu64" => Intrinsic {
-            inputs: vec![v(u(32), 8), v(u(32), 8)],
-            output: v(u(64), 4),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U32x8, &::U32x8]; &INPUTS },
+            output: &::U64x4,
             definition: Named("llvm.x86.avx2.pmulq.dq")
         },
         "256_mulhi_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.pmulhw.w")
         },
         "256_mulhi_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 16), v(u(16), 16)],
-            output: v(u(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x16, &::U16x16]; &INPUTS },
+            output: &::U16x16,
             definition: Named("llvm.x86.avx2.pmulhw.w")
         },
         "256_mulhrs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.pmul.hr.sw")
         },
         "256_packs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I8x32,
             definition: Named("llvm.x86.avx2.packsswb")
         },
         "256_packus_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(u(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::U8x32,
             definition: Named("llvm.x86.avx2.packuswb")
         },
         "256_packs_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.packssdw")
         },
         "256_packus_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(u(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::U16x16,
             definition: Named("llvm.x86.avx2.packusdw")
         },
         "256_permutevar8x32_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.permd")
         },
         "256_permutevar8x32_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(i(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::F32x8, &::I32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.avx2.permps")
         },
         "256_sad_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 32), v(u(8), 32)],
-            output: v(u(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x32, &::U8x32]; &INPUTS },
+            output: &::U8x32,
             definition: Named("llvm.x86.avx2.psad.bw")
         },
         "256_shuffle_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 32), v(i(8), 32)],
-            output: v(i(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x32, &::I8x32]; &INPUTS },
+            output: &::I8x32,
             definition: Named("llvm.x86.avx2.pshuf.b")
         },
         "256_sign_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 32), v(i(8), 32)],
-            output: v(i(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x32, &::I8x32]; &INPUTS },
+            output: &::I8x32,
             definition: Named("llvm.x86.avx2.psign.b")
         },
         "256_sign_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.psign.w")
         },
         "256_sign_epi32" => Intrinsic {
-            inputs: vec![v(i(32), 8), v(i(32), 8)],
-            output: v(i(32), 8),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I32x8, &::I32x8]; &INPUTS },
+            output: &::I32x8,
             definition: Named("llvm.x86.avx2.psign.d")
         },
         "256_subs_epi8" => Intrinsic {
-            inputs: vec![v(i(8), 32), v(i(8), 32)],
-            output: v(i(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I8x32, &::I8x32]; &INPUTS },
+            output: &::I8x32,
             definition: Named("llvm.x86.avx2.psubs.b")
         },
         "256_subs_epu8" => Intrinsic {
-            inputs: vec![v(u(8), 32), v(u(8), 32)],
-            output: v(u(8), 32),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U8x32, &::U8x32]; &INPUTS },
+            output: &::U8x32,
             definition: Named("llvm.x86.avx2.psubus.b")
         },
         "256_subs_epi16" => Intrinsic {
-            inputs: vec![v(i(16), 16), v(i(16), 16)],
-            output: v(i(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::I16x16, &::I16x16]; &INPUTS },
+            output: &::I16x16,
             definition: Named("llvm.x86.avx2.psubs.w")
         },
         "256_subs_epu16" => Intrinsic {
-            inputs: vec![v(u(16), 16), v(u(16), 16)],
-            output: v(u(16), 16),
+            inputs: { static INPUTS: [&'static Type; 2] = [&::U16x16, &::U16x16]; &INPUTS },
+            output: &::U16x16,
             definition: Named("llvm.x86.avx2.psubus.w")
         },
         "_fmadd_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.fma.vfmadd.ps")
         },
         "_fmadd_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.fma.vfmadd.pd")
         },
         "256_fmadd_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.fma.vfmadd.ps.256")
         },
         "256_fmadd_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x4, &::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.fma.vfmadd.pd.256")
         },
         "_fmaddsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.fma.vfmaddsub.ps")
         },
         "_fmaddsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.fma.vfmaddsub.pd")
         },
         "256_fmaddsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.fma.vfmaddsub.ps.256")
         },
         "256_fmaddsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x4, &::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.fma.vfmaddsub.pd.256")
         },
         "_fmsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.fma.vfmsub.ps")
         },
         "_fmsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.fma.vfmsub.pd")
         },
         "256_fmsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.fma.vfmsub.ps.256")
         },
         "256_fmsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x4, &::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.fma.vfmsub.pd.256")
         },
         "_fmsubadd_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.fma.vfmsubadd.ps")
         },
         "_fmsubadd_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.fma.vfmsubadd.pd")
         },
         "256_fmsubadd_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.fma.vfmsubadd.ps.256")
         },
         "256_fmsubadd_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x4, &::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.fma.vfmsubadd.pd.256")
         },
         "_fnmadd_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.fma.vfnmadd.ps")
         },
         "_fnmadd_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.fma.vfnmadd.pd")
         },
         "256_fnmadd_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.fma.vfnmadd.ps.256")
         },
         "256_fnmadd_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x4, &::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.fma.vfnmadd.pd.256")
         },
         "_fnmsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 4), v(f(32), 4), v(f(32), 4)],
-            output: v(f(32), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x4, &::F32x4, &::F32x4]; &INPUTS },
+            output: &::F32x4,
             definition: Named("llvm.x86.fma.vfnmsub.ps")
         },
         "_fnmsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 2), v(f(64), 2), v(f(64), 2)],
-            output: v(f(64), 2),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x2, &::F64x2, &::F64x2]; &INPUTS },
+            output: &::F64x2,
             definition: Named("llvm.x86.fma.vfnmsub.pd")
         },
         "256_fnmsub_ps" => Intrinsic {
-            inputs: vec![v(f(32), 8), v(f(32), 8), v(f(32), 8)],
-            output: v(f(32), 8),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F32x8, &::F32x8, &::F32x8]; &INPUTS },
+            output: &::F32x8,
             definition: Named("llvm.x86.fma.vfnmsub.ps.256")
         },
         "256_fnmsub_pd" => Intrinsic {
-            inputs: vec![v(f(64), 4), v(f(64), 4), v(f(64), 4)],
-            output: v(f(64), 4),
+            inputs: { static INPUTS: [&'static Type; 3] = [&::F64x4, &::F64x4, &::F64x4]; &INPUTS },
+            output: &::F64x4,
             definition: Named("llvm.x86.fma.vfnmsub.pd.256")
         },
         _ => return None,
index ac1d34f17064eb050d991efc3b8a79ef108538a5..ca9833f6f9d69cf72c1a5211e70ef565e20f14c9 100644 (file)
@@ -955,7 +955,7 @@ fn modify_as_needed<'blk, 'tcx>(bcx: Block<'blk, 'tcx>,
                 }
             };
 
-            match intr.output {
+            match *intr.output {
                 intrinsics::Type::Aggregate(flatten, ref elems) => {
                     // the output is a tuple so we need to munge it properly
                     assert!(!flatten);