1*6881a400Schristos /* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: 2*6881a400Schristos Original: cskyv2-linux.xml */ 3*6881a400Schristos 4*6881a400Schristos #include "gdbsupport/tdesc.h" 5*6881a400Schristos 6*6881a400Schristos static int 7*6881a400Schristos create_feature_cskyv2_linux (struct target_desc *result, long regnum) 8*6881a400Schristos { 9*6881a400Schristos struct tdesc_feature *feature; 10*6881a400Schristos 11*6881a400Schristos feature = tdesc_create_feature (result, "org.gnu.gdb.csky.abiv2"); 12*6881a400Schristos tdesc_type *element_type; 13*6881a400Schristos element_type = tdesc_named_type (feature, "ieee_single"); 14*6881a400Schristos tdesc_create_vector (feature, "v4f", element_type, 4); 15*6881a400Schristos 16*6881a400Schristos element_type = tdesc_named_type (feature, "ieee_double"); 17*6881a400Schristos tdesc_create_vector (feature, "v2d", element_type, 2); 18*6881a400Schristos 19*6881a400Schristos element_type = tdesc_named_type (feature, "int8"); 20*6881a400Schristos tdesc_create_vector (feature, "v16i8", element_type, 16); 21*6881a400Schristos 22*6881a400Schristos element_type = tdesc_named_type (feature, "int16"); 23*6881a400Schristos tdesc_create_vector (feature, "v8i16", element_type, 8); 24*6881a400Schristos 25*6881a400Schristos element_type = tdesc_named_type (feature, "int32"); 26*6881a400Schristos tdesc_create_vector (feature, "v4i32", element_type, 4); 27*6881a400Schristos 28*6881a400Schristos element_type = tdesc_named_type (feature, "int64"); 29*6881a400Schristos tdesc_create_vector (feature, "v2i64", element_type, 2); 30*6881a400Schristos 31*6881a400Schristos tdesc_type_with_fields *type_with_fields; 32*6881a400Schristos type_with_fields = tdesc_create_union (feature, "vec128"); 33*6881a400Schristos tdesc_type *field_type; 34*6881a400Schristos field_type = tdesc_named_type (feature, "v4f"); 35*6881a400Schristos tdesc_add_field (type_with_fields, "v4_float", field_type); 36*6881a400Schristos field_type = tdesc_named_type (feature, "v2d"); 37*6881a400Schristos tdesc_add_field (type_with_fields, "v2_double", field_type); 38*6881a400Schristos field_type = tdesc_named_type (feature, "v16i8"); 39*6881a400Schristos tdesc_add_field (type_with_fields, "v16_int8", field_type); 40*6881a400Schristos field_type = tdesc_named_type (feature, "v8i16"); 41*6881a400Schristos tdesc_add_field (type_with_fields, "v8_int16", field_type); 42*6881a400Schristos field_type = tdesc_named_type (feature, "v4i32"); 43*6881a400Schristos tdesc_add_field (type_with_fields, "v4_int32", field_type); 44*6881a400Schristos field_type = tdesc_named_type (feature, "v2i64"); 45*6881a400Schristos tdesc_add_field (type_with_fields, "v2_int64", field_type); 46*6881a400Schristos field_type = tdesc_named_type (feature, "uint128"); 47*6881a400Schristos tdesc_add_field (type_with_fields, "uint128", field_type); 48*6881a400Schristos 49*6881a400Schristos tdesc_create_reg (feature, "r0", regnum++, 1, NULL, 32, "int"); 50*6881a400Schristos tdesc_create_reg (feature, "r1", regnum++, 1, NULL, 32, "int"); 51*6881a400Schristos tdesc_create_reg (feature, "r2", regnum++, 1, NULL, 32, "int"); 52*6881a400Schristos tdesc_create_reg (feature, "r3", regnum++, 1, NULL, 32, "int"); 53*6881a400Schristos tdesc_create_reg (feature, "r4", regnum++, 1, NULL, 32, "int"); 54*6881a400Schristos tdesc_create_reg (feature, "r5", regnum++, 1, NULL, 32, "int"); 55*6881a400Schristos tdesc_create_reg (feature, "r6", regnum++, 1, NULL, 32, "int"); 56*6881a400Schristos tdesc_create_reg (feature, "r7", regnum++, 1, NULL, 32, "int"); 57*6881a400Schristos tdesc_create_reg (feature, "r8", regnum++, 1, NULL, 32, "int"); 58*6881a400Schristos tdesc_create_reg (feature, "r9", regnum++, 1, NULL, 32, "int"); 59*6881a400Schristos tdesc_create_reg (feature, "r10", regnum++, 1, NULL, 32, "int"); 60*6881a400Schristos tdesc_create_reg (feature, "r11", regnum++, 1, NULL, 32, "int"); 61*6881a400Schristos tdesc_create_reg (feature, "r12", regnum++, 1, NULL, 32, "int"); 62*6881a400Schristos tdesc_create_reg (feature, "r13", regnum++, 1, NULL, 32, "int"); 63*6881a400Schristos tdesc_create_reg (feature, "r14", regnum++, 1, NULL, 32, "data_ptr"); 64*6881a400Schristos tdesc_create_reg (feature, "r15", regnum++, 1, NULL, 32, "int"); 65*6881a400Schristos tdesc_create_reg (feature, "r16", regnum++, 1, NULL, 32, "int"); 66*6881a400Schristos tdesc_create_reg (feature, "r17", regnum++, 1, NULL, 32, "int"); 67*6881a400Schristos tdesc_create_reg (feature, "r18", regnum++, 1, NULL, 32, "int"); 68*6881a400Schristos tdesc_create_reg (feature, "r19", regnum++, 1, NULL, 32, "int"); 69*6881a400Schristos tdesc_create_reg (feature, "r20", regnum++, 1, NULL, 32, "int"); 70*6881a400Schristos tdesc_create_reg (feature, "r21", regnum++, 1, NULL, 32, "int"); 71*6881a400Schristos tdesc_create_reg (feature, "r22", regnum++, 1, NULL, 32, "int"); 72*6881a400Schristos tdesc_create_reg (feature, "r23", regnum++, 1, NULL, 32, "int"); 73*6881a400Schristos tdesc_create_reg (feature, "r24", regnum++, 1, NULL, 32, "int"); 74*6881a400Schristos tdesc_create_reg (feature, "r25", regnum++, 1, NULL, 32, "int"); 75*6881a400Schristos tdesc_create_reg (feature, "r26", regnum++, 1, NULL, 32, "int"); 76*6881a400Schristos tdesc_create_reg (feature, "r27", regnum++, 1, NULL, 32, "int"); 77*6881a400Schristos tdesc_create_reg (feature, "r28", regnum++, 1, NULL, 32, "int"); 78*6881a400Schristos tdesc_create_reg (feature, "r29", regnum++, 1, NULL, 32, "int"); 79*6881a400Schristos tdesc_create_reg (feature, "r30", regnum++, 1, NULL, 32, "int"); 80*6881a400Schristos tdesc_create_reg (feature, "r31", regnum++, 1, NULL, 32, "int"); 81*6881a400Schristos regnum = 36; 82*6881a400Schristos tdesc_create_reg (feature, "hi", regnum++, 1, NULL, 32, "int"); 83*6881a400Schristos tdesc_create_reg (feature, "lo", regnum++, 1, NULL, 32, "int"); 84*6881a400Schristos regnum = 40; 85*6881a400Schristos tdesc_create_reg (feature, "fr0", regnum++, 1, NULL, 64, "ieee_double"); 86*6881a400Schristos tdesc_create_reg (feature, "fr1", regnum++, 1, NULL, 64, "ieee_double"); 87*6881a400Schristos tdesc_create_reg (feature, "fr2", regnum++, 1, NULL, 64, "ieee_double"); 88*6881a400Schristos tdesc_create_reg (feature, "fr3", regnum++, 1, NULL, 64, "ieee_double"); 89*6881a400Schristos tdesc_create_reg (feature, "fr4", regnum++, 1, NULL, 64, "ieee_double"); 90*6881a400Schristos tdesc_create_reg (feature, "fr5", regnum++, 1, NULL, 64, "ieee_double"); 91*6881a400Schristos tdesc_create_reg (feature, "fr6", regnum++, 1, NULL, 64, "ieee_double"); 92*6881a400Schristos tdesc_create_reg (feature, "fr7", regnum++, 1, NULL, 64, "ieee_double"); 93*6881a400Schristos tdesc_create_reg (feature, "fr8", regnum++, 1, NULL, 64, "ieee_double"); 94*6881a400Schristos tdesc_create_reg (feature, "fr9", regnum++, 1, NULL, 64, "ieee_double"); 95*6881a400Schristos tdesc_create_reg (feature, "fr10", regnum++, 1, NULL, 64, "ieee_double"); 96*6881a400Schristos tdesc_create_reg (feature, "fr11", regnum++, 1, NULL, 64, "ieee_double"); 97*6881a400Schristos tdesc_create_reg (feature, "fr12", regnum++, 1, NULL, 64, "ieee_double"); 98*6881a400Schristos tdesc_create_reg (feature, "fr13", regnum++, 1, NULL, 64, "ieee_double"); 99*6881a400Schristos tdesc_create_reg (feature, "fr14", regnum++, 1, NULL, 64, "ieee_double"); 100*6881a400Schristos tdesc_create_reg (feature, "fr15", regnum++, 1, NULL, 64, "ieee_double"); 101*6881a400Schristos tdesc_create_reg (feature, "vr0", regnum++, 1, NULL, 128, "vec128"); 102*6881a400Schristos tdesc_create_reg (feature, "vr1", regnum++, 1, NULL, 128, "vec128"); 103*6881a400Schristos tdesc_create_reg (feature, "vr2", regnum++, 1, NULL, 128, "vec128"); 104*6881a400Schristos tdesc_create_reg (feature, "vr3", regnum++, 1, NULL, 128, "vec128"); 105*6881a400Schristos tdesc_create_reg (feature, "vr4", regnum++, 1, NULL, 128, "vec128"); 106*6881a400Schristos tdesc_create_reg (feature, "vr5", regnum++, 1, NULL, 128, "vec128"); 107*6881a400Schristos tdesc_create_reg (feature, "vr6", regnum++, 1, NULL, 128, "vec128"); 108*6881a400Schristos tdesc_create_reg (feature, "vr7", regnum++, 1, NULL, 128, "vec128"); 109*6881a400Schristos tdesc_create_reg (feature, "vr8", regnum++, 1, NULL, 128, "vec128"); 110*6881a400Schristos tdesc_create_reg (feature, "vr9", regnum++, 1, NULL, 128, "vec128"); 111*6881a400Schristos tdesc_create_reg (feature, "vr10", regnum++, 1, NULL, 128, "vec128"); 112*6881a400Schristos tdesc_create_reg (feature, "vr11", regnum++, 1, NULL, 128, "vec128"); 113*6881a400Schristos tdesc_create_reg (feature, "vr12", regnum++, 1, NULL, 128, "vec128"); 114*6881a400Schristos tdesc_create_reg (feature, "vr13", regnum++, 1, NULL, 128, "vec128"); 115*6881a400Schristos tdesc_create_reg (feature, "vr14", regnum++, 1, NULL, 128, "vec128"); 116*6881a400Schristos tdesc_create_reg (feature, "vr15", regnum++, 1, NULL, 128, "vec128"); 117*6881a400Schristos tdesc_create_reg (feature, "pc", regnum++, 1, NULL, 32, "code_ptr"); 118*6881a400Schristos regnum = 89; 119*6881a400Schristos tdesc_create_reg (feature, "psr", regnum++, 1, NULL, 32, "int"); 120*6881a400Schristos regnum = 121; 121*6881a400Schristos tdesc_create_reg (feature, "fid", regnum++, 1, NULL, 32, "int"); 122*6881a400Schristos tdesc_create_reg (feature, "fcr", regnum++, 1, NULL, 32, "int"); 123*6881a400Schristos tdesc_create_reg (feature, "fesr", regnum++, 1, NULL, 32, "int"); 124*6881a400Schristos regnum = 127; 125*6881a400Schristos tdesc_create_reg (feature, "usp", regnum++, 1, NULL, 32, "int"); 126*6881a400Schristos return regnum; 127*6881a400Schristos } 128