1 //===-- Scalar.cpp ----------------------------------------------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 #include "lldb/Core/Scalar.h"
12 #include "lldb/Utility/DataExtractor.h"
13 #include "lldb/Utility/Endian.h"
14 #include "lldb/Utility/Status.h"
15 #include "lldb/Utility/Stream.h"
16 #include "lldb/lldb-types.h" // for offset_t
18 #include "llvm/ADT/SmallString.h"
24 using namespace lldb_private;
26 //----------------------------------------------------------------------
27 // Promote to max type currently follows the ANSI C rule for type promotion in
29 //----------------------------------------------------------------------
30 static Scalar::Type PromoteToMaxType(
31 const Scalar &lhs, // The const left hand side object
32 const Scalar &rhs, // The const right hand side object
33 Scalar &temp_value, // A modifiable temp value than can be used to hold
34 // either the promoted lhs or rhs object
35 const Scalar *&promoted_lhs_ptr, // Pointer to the resulting possibly
36 // promoted value of lhs (at most one of
37 // lhs/rhs will get promoted)
38 const Scalar *&promoted_rhs_ptr // Pointer to the resulting possibly
39 // promoted value of rhs (at most one of
40 // lhs/rhs will get promoted)
43 // Initialize the promoted values for both the right and left hand side
44 // values to be the objects themselves. If no promotion is needed (both right
45 // and left have the same type), then the temp_value will not get used.
46 promoted_lhs_ptr = &lhs;
47 promoted_rhs_ptr = &rhs;
48 // Extract the types of both the right and left hand side values
49 Scalar::Type lhs_type = lhs.GetType();
50 Scalar::Type rhs_type = rhs.GetType();
52 if (lhs_type > rhs_type) {
53 // Right hand side need to be promoted
54 temp_value = rhs; // Copy right hand side into the temp value
55 if (temp_value.Promote(lhs_type)) // Promote it
57 &temp_value; // Update the pointer for the promoted right hand side
58 } else if (lhs_type < rhs_type) {
59 // Left hand side need to be promoted
60 temp_value = lhs; // Copy left hand side value into the temp value
61 if (temp_value.Promote(rhs_type)) // Promote it
63 &temp_value; // Update the pointer for the promoted left hand side
66 // Make sure our type promotion worked as expected
67 if (promoted_lhs_ptr->GetType() == promoted_rhs_ptr->GetType())
68 return promoted_lhs_ptr->GetType(); // Return the resulting max type
70 // Return the void type (zero) if we fail to promote either of the values.
71 return Scalar::e_void;
74 Scalar::Scalar() : m_type(e_void), m_float((float)0) {}
76 Scalar::Scalar(const Scalar &rhs)
77 : m_type(rhs.m_type), m_integer(rhs.m_integer), m_float(rhs.m_float) {}
79 // Scalar::Scalar(const RegisterValue& reg) :
83 // switch (reg.info.encoding)
85 // case eEncodingUint: // unsigned integer
86 // switch (reg.info.byte_size)
88 // case 1: m_type = e_uint; m_data.uint = reg.value.uint8; break;
89 // case 2: m_type = e_uint; m_data.uint = reg.value.uint16; break;
90 // case 4: m_type = e_uint; m_data.uint = reg.value.uint32; break;
91 // case 8: m_type = e_ulonglong; m_data.ulonglong = reg.value.uint64;
97 // case eEncodingSint: // signed integer
98 // switch (reg.info.byte_size)
100 // case 1: m_type = e_sint; m_data.sint = reg.value.sint8; break;
101 // case 2: m_type = e_sint; m_data.sint = reg.value.sint16; break;
102 // case 4: m_type = e_sint; m_data.sint = reg.value.sint32; break;
103 // case 8: m_type = e_slonglong; m_data.slonglong = reg.value.sint64;
109 // case eEncodingIEEE754: // float
110 // switch (reg.info.byte_size)
112 // case 4: m_type = e_float; m_data.flt = reg.value.float32; break;
113 // case 8: m_type = e_double; m_data.dbl = reg.value.float64; break;
117 // case eEncodingVector: // vector registers
122 bool Scalar::GetData(DataExtractor &data, size_t limit_byte_size) const {
123 size_t byte_size = GetByteSize();
125 const uint8_t *bytes = reinterpret_cast<const uint8_t *>(GetBytes());
127 if (limit_byte_size < byte_size) {
128 if (endian::InlHostByteOrder() == eByteOrderLittle) {
129 // On little endian systems if we want fewer bytes from the current
130 // type we just specify fewer bytes since the LSByte is first...
131 byte_size = limit_byte_size;
132 } else if (endian::InlHostByteOrder() == eByteOrderBig) {
133 // On big endian systems if we want fewer bytes from the current type
134 // have to advance our initial byte pointer and trim down the number of
135 // bytes since the MSByte is first
136 bytes += byte_size - limit_byte_size;
137 byte_size = limit_byte_size;
141 data.SetData(bytes, byte_size, endian::InlHostByteOrder());
148 const void *Scalar::GetBytes() const {
149 const uint64_t *apint_words;
150 const uint8_t *bytes;
151 static float_t flt_val;
152 static double_t dbl_val;
153 static uint64_t swapped_words[4];
163 bytes = reinterpret_cast<const uint8_t *>(m_integer.getRawData());
164 // getRawData always returns a pointer to an uint64_t. If we have a
165 // smaller type, we need to update the pointer on big-endian systems.
166 if (endian::InlHostByteOrder() == eByteOrderBig) {
167 size_t byte_size = m_integer.getBitWidth() / 8;
169 bytes += 8 - byte_size;
174 apint_words = m_integer.getRawData();
175 // getRawData always returns a pointer to an array of two uint64_t values,
176 // where the least-significant word always comes first. On big-endian
177 // systems we need to swap the two words.
178 if (endian::InlHostByteOrder() == eByteOrderBig) {
179 swapped_words[0] = apint_words[1];
180 swapped_words[1] = apint_words[0];
181 apint_words = swapped_words;
183 return reinterpret_cast<const void *>(apint_words);
186 apint_words = m_integer.getRawData();
187 // getRawData always returns a pointer to an array of four uint64_t values,
188 // where the least-significant word always comes first. On big-endian
189 // systems we need to swap the four words.
190 if (endian::InlHostByteOrder() == eByteOrderBig) {
191 swapped_words[0] = apint_words[3];
192 swapped_words[1] = apint_words[2];
193 swapped_words[2] = apint_words[1];
194 swapped_words[3] = apint_words[0];
195 apint_words = swapped_words;
197 return reinterpret_cast<const void *>(apint_words);
199 flt_val = m_float.convertToFloat();
200 return reinterpret_cast<const void *>(&flt_val);
202 dbl_val = m_float.convertToDouble();
203 return reinterpret_cast<const void *>(&dbl_val);
205 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
206 apint_words = ldbl_val.getRawData();
207 // getRawData always returns a pointer to an array of two uint64_t values,
208 // where the least-significant word always comes first. On big-endian
209 // systems we need to swap the two words.
210 if (endian::InlHostByteOrder() == eByteOrderBig) {
211 swapped_words[0] = apint_words[1];
212 swapped_words[1] = apint_words[0];
213 apint_words = swapped_words;
215 return reinterpret_cast<const void *>(apint_words);
220 size_t Scalar::GetByteSize() const {
234 return (m_integer.getBitWidth() / 8);
236 return sizeof(float_t);
238 return sizeof(double_t);
240 return sizeof(long_double_t);
245 bool Scalar::IsZero() const {
246 llvm::APInt zero_int = llvm::APInt::getNullValue(m_integer.getBitWidth() / 8);
260 return llvm::APInt::isSameValue(zero_int, m_integer);
264 return m_float.isZero();
269 void Scalar::GetValue(Stream *s, bool show_type) const {
271 s->Printf("(%s) ", GetTypeAsCString());
281 s->PutCString(m_integer.toString(10, true));
288 s->PutCString(m_integer.toString(10, false));
293 llvm::SmallString<24> string;
294 m_float.toString(string);
295 s->Printf("%s", string.c_str());
300 const char *Scalar::GetTypeAsCString() const {
307 return "unsigned int";
311 return "unsigned long";
315 return "unsigned long long";
319 return "unsigned int128_t";
323 return "unsigned int256_t";
329 return "long double";
331 return "<invalid Scalar type>";
334 Scalar &Scalar::operator=(const Scalar &rhs) {
337 m_integer = llvm::APInt(rhs.m_integer);
338 m_float = rhs.m_float;
343 Scalar &Scalar::operator=(const int v) {
345 m_integer = llvm::APInt(sizeof(int) * 8, v, true);
349 Scalar &Scalar::operator=(unsigned int v) {
351 m_integer = llvm::APInt(sizeof(int) * 8, v);
355 Scalar &Scalar::operator=(long v) {
357 m_integer = llvm::APInt(sizeof(long) * 8, v, true);
361 Scalar &Scalar::operator=(unsigned long v) {
363 m_integer = llvm::APInt(sizeof(long) * 8, v);
367 Scalar &Scalar::operator=(long long v) {
368 m_type = e_slonglong;
369 m_integer = llvm::APInt(sizeof(long) * 8, v, true);
373 Scalar &Scalar::operator=(unsigned long long v) {
374 m_type = e_ulonglong;
375 m_integer = llvm::APInt(sizeof(long long) * 8, v);
379 Scalar &Scalar::operator=(float v) {
381 m_float = llvm::APFloat(v);
385 Scalar &Scalar::operator=(double v) {
387 m_float = llvm::APFloat(v);
391 Scalar &Scalar::operator=(long double v) {
392 m_type = e_long_double;
394 m_float = llvm::APFloat(
395 llvm::APFloat::IEEEquad(),
396 llvm::APInt(BITWIDTH_INT128, NUM_OF_WORDS_INT128, ((type128 *)&v)->x));
398 m_float = llvm::APFloat(
399 llvm::APFloat::x87DoubleExtended(),
400 llvm::APInt(BITWIDTH_INT128, NUM_OF_WORDS_INT128, ((type128 *)&v)->x));
404 Scalar &Scalar::operator=(llvm::APInt rhs) {
405 m_integer = llvm::APInt(rhs);
406 switch (m_integer.getBitWidth()) {
410 if (m_integer.isSignedIntN(sizeof(sint_t) * 8))
416 if (m_integer.isSignedIntN(sizeof(slonglong_t) * 8))
417 m_type = e_slonglong;
419 m_type = e_ulonglong;
422 if (m_integer.isSignedIntN(BITWIDTH_INT128))
428 if (m_integer.isSignedIntN(BITWIDTH_INT256))
437 Scalar::~Scalar() = default;
439 bool Scalar::Promote(Scalar::Type type) {
440 bool success = false;
453 m_integer = m_integer.sextOrTrunc(sizeof(uint_t) * 8);
458 m_integer = m_integer.sextOrTrunc(sizeof(slong_t) * 8);
463 m_integer = m_integer.sextOrTrunc(sizeof(ulong_t) * 8);
468 m_integer = m_integer.sextOrTrunc(sizeof(slonglong_t) * 8);
473 m_integer = m_integer.sextOrTrunc(sizeof(ulonglong_t) * 8);
479 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT128);
485 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT256);
490 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
491 m_float.convertFromAPInt(m_integer, true,
492 llvm::APFloat::rmNearestTiesToEven);
497 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
498 m_float.convertFromAPInt(m_integer, true,
499 llvm::APFloat::rmNearestTiesToEven);
504 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
505 : llvm::APFloat::x87DoubleExtended());
506 m_float.convertFromAPInt(m_integer, true,
507 llvm::APFloat::rmNearestTiesToEven);
522 m_integer = m_integer.zextOrTrunc(sizeof(slong_t) * 8);
527 m_integer = m_integer.zextOrTrunc(sizeof(ulong_t) * 8);
532 m_integer = m_integer.zextOrTrunc(sizeof(slonglong_t) * 8);
537 m_integer = m_integer.zextOrTrunc(sizeof(ulonglong_t) * 8);
543 m_integer = m_integer.zextOrTrunc(BITWIDTH_INT128);
549 m_integer = m_integer.zextOrTrunc(BITWIDTH_INT256);
554 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
555 m_float.convertFromAPInt(m_integer, false,
556 llvm::APFloat::rmNearestTiesToEven);
561 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
562 m_float.convertFromAPInt(m_integer, false,
563 llvm::APFloat::rmNearestTiesToEven);
568 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
569 : llvm::APFloat::x87DoubleExtended());
570 m_float.convertFromAPInt(m_integer, false,
571 llvm::APFloat::rmNearestTiesToEven);
587 m_integer = m_integer.sextOrTrunc(sizeof(ulong_t) * 8);
592 m_integer = m_integer.sextOrTrunc(sizeof(slonglong_t) * 8);
597 m_integer = m_integer.sextOrTrunc(sizeof(ulonglong_t) * 8);
603 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT128);
609 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT256);
614 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
615 m_float.convertFromAPInt(m_integer, true,
616 llvm::APFloat::rmNearestTiesToEven);
621 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
622 m_float.convertFromAPInt(m_integer, true,
623 llvm::APFloat::rmNearestTiesToEven);
628 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
629 : llvm::APFloat::x87DoubleExtended());
630 m_float.convertFromAPInt(m_integer, true,
631 llvm::APFloat::rmNearestTiesToEven);
648 m_integer = m_integer.zextOrTrunc(sizeof(slonglong_t) * 8);
653 m_integer = m_integer.zextOrTrunc(sizeof(ulonglong_t) * 8);
659 m_integer = m_integer.zextOrTrunc(BITWIDTH_INT128);
665 m_integer = m_integer.zextOrTrunc(BITWIDTH_INT256);
670 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
671 m_float.convertFromAPInt(m_integer, false,
672 llvm::APFloat::rmNearestTiesToEven);
677 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
678 m_float.convertFromAPInt(m_integer, false,
679 llvm::APFloat::rmNearestTiesToEven);
684 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
685 : llvm::APFloat::x87DoubleExtended());
686 m_float.convertFromAPInt(m_integer, false,
687 llvm::APFloat::rmNearestTiesToEven);
705 m_integer = m_integer.sextOrTrunc(sizeof(ulonglong_t) * 8);
711 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT128);
717 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT256);
722 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
723 m_float.convertFromAPInt(m_integer, true,
724 llvm::APFloat::rmNearestTiesToEven);
729 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
730 m_float.convertFromAPInt(m_integer, true,
731 llvm::APFloat::rmNearestTiesToEven);
736 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
737 : llvm::APFloat::x87DoubleExtended());
738 m_float.convertFromAPInt(m_integer, true,
739 llvm::APFloat::rmNearestTiesToEven);
759 m_integer = m_integer.zextOrTrunc(BITWIDTH_INT128);
765 m_integer = m_integer.zextOrTrunc(BITWIDTH_INT256);
770 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
771 m_float.convertFromAPInt(m_integer, false,
772 llvm::APFloat::rmNearestTiesToEven);
777 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
778 m_float.convertFromAPInt(m_integer, false,
779 llvm::APFloat::rmNearestTiesToEven);
784 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
785 : llvm::APFloat::x87DoubleExtended());
786 m_float.convertFromAPInt(m_integer, false,
787 llvm::APFloat::rmNearestTiesToEven);
807 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT128);
813 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT256);
818 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
819 m_float.convertFromAPInt(m_integer, true,
820 llvm::APFloat::rmNearestTiesToEven);
825 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
826 m_float.convertFromAPInt(m_integer, true,
827 llvm::APFloat::rmNearestTiesToEven);
832 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
833 : llvm::APFloat::x87DoubleExtended());
834 m_float.convertFromAPInt(m_integer, true,
835 llvm::APFloat::rmNearestTiesToEven);
857 m_integer = m_integer.zextOrTrunc(BITWIDTH_INT256);
862 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
863 m_float.convertFromAPInt(m_integer, false,
864 llvm::APFloat::rmNearestTiesToEven);
869 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
870 m_float.convertFromAPInt(m_integer, false,
871 llvm::APFloat::rmNearestTiesToEven);
876 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
877 : llvm::APFloat::x87DoubleExtended());
878 m_float.convertFromAPInt(m_integer, false,
879 llvm::APFloat::rmNearestTiesToEven);
901 m_integer = m_integer.sextOrTrunc(BITWIDTH_INT256);
906 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
907 m_float.convertFromAPInt(m_integer, true,
908 llvm::APFloat::rmNearestTiesToEven);
913 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
914 m_float.convertFromAPInt(m_integer, true,
915 llvm::APFloat::rmNearestTiesToEven);
920 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
921 : llvm::APFloat::x87DoubleExtended());
922 m_float.convertFromAPInt(m_integer, true,
923 llvm::APFloat::rmNearestTiesToEven);
946 m_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
947 m_float.convertFromAPInt(m_integer, false,
948 llvm::APFloat::rmNearestTiesToEven);
953 m_float = llvm::APFloat(llvm::APFloat::IEEEdouble());
954 m_float.convertFromAPInt(m_integer, false,
955 llvm::APFloat::rmNearestTiesToEven);
960 m_float = llvm::APFloat(m_ieee_quad ? llvm::APFloat::IEEEquad()
961 : llvm::APFloat::x87DoubleExtended());
962 m_float.convertFromAPInt(m_integer, false,
963 llvm::APFloat::rmNearestTiesToEven);
987 m_float = llvm::APFloat((double_t)m_float.convertToFloat());
991 case e_long_double: {
993 m_float.convert(m_ieee_quad ? llvm::APFloat::IEEEquad()
994 : llvm::APFloat::x87DoubleExtended(),
995 llvm::APFloat::rmNearestTiesToEven, &ignore);
1020 case e_long_double: {
1022 m_float.convert(m_ieee_quad ? llvm::APFloat::IEEEquad()
1023 : llvm::APFloat::x87DoubleExtended(),
1024 llvm::APFloat::rmNearestTiesToEven, &ignore);
1059 const char *Scalar::GetValueTypeAsCString(Scalar::Type type) {
1066 return "unsigned int";
1070 return "unsigned long";
1074 return "unsigned long long";
1080 return "long double";
1094 Scalar::GetValueTypeForSignedIntegerWithByteSize(size_t byte_size) {
1095 if (byte_size <= sizeof(sint_t))
1097 if (byte_size <= sizeof(slong_t))
1099 if (byte_size <= sizeof(slonglong_t))
1105 Scalar::GetValueTypeForUnsignedIntegerWithByteSize(size_t byte_size) {
1106 if (byte_size <= sizeof(uint_t))
1108 if (byte_size <= sizeof(ulong_t))
1110 if (byte_size <= sizeof(ulonglong_t))
1115 Scalar::Type Scalar::GetValueTypeForFloatWithByteSize(size_t byte_size) {
1116 if (byte_size == sizeof(float_t))
1118 if (byte_size == sizeof(double_t))
1120 if (byte_size == sizeof(long_double_t))
1121 return e_long_double;
1125 bool Scalar::MakeSigned() {
1126 bool success = false;
1149 m_type = e_slonglong;
1180 bool Scalar::MakeUnsigned() {
1181 bool success = false;
1201 m_type = e_ulonglong;
1235 signed char Scalar::SChar(char fail_value) const {
1249 return (schar_t)(m_integer.sextOrTrunc(sizeof(schar_t) * 8)).getSExtValue();
1251 return (schar_t)m_float.convertToFloat();
1253 return (schar_t)m_float.convertToDouble();
1255 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1256 return (schar_t)(ldbl_val.sextOrTrunc(sizeof(schar_t) * 8)).getSExtValue();
1261 unsigned char Scalar::UChar(unsigned char fail_value) const {
1275 return (uchar_t)(m_integer.zextOrTrunc(sizeof(uchar_t) * 8)).getZExtValue();
1277 return (uchar_t)m_float.convertToFloat();
1279 return (uchar_t)m_float.convertToDouble();
1281 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1282 return (uchar_t)(ldbl_val.zextOrTrunc(sizeof(uchar_t) * 8)).getZExtValue();
1287 short Scalar::SShort(short fail_value) const {
1301 return (sshort_t)(m_integer.sextOrTrunc(sizeof(sshort_t) * 8))
1304 return (sshort_t)m_float.convertToFloat();
1306 return (sshort_t)m_float.convertToDouble();
1308 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1309 return (sshort_t)(ldbl_val.sextOrTrunc(sizeof(sshort_t) * 8))
1315 unsigned short Scalar::UShort(unsigned short fail_value) const {
1329 return (ushort_t)(m_integer.zextOrTrunc(sizeof(ushort_t) * 8))
1332 return (ushort_t)m_float.convertToFloat();
1334 return (ushort_t)m_float.convertToDouble();
1336 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1337 return (ushort_t)(ldbl_val.zextOrTrunc(sizeof(ushort_t) * 8))
1343 int Scalar::SInt(int fail_value) const {
1357 return (sint_t)(m_integer.sextOrTrunc(sizeof(sint_t) * 8)).getSExtValue();
1359 return (sint_t)m_float.convertToFloat();
1361 return (sint_t)m_float.convertToDouble();
1363 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1364 return (sint_t)(ldbl_val.sextOrTrunc(sizeof(sint_t) * 8)).getSExtValue();
1369 unsigned int Scalar::UInt(unsigned int fail_value) const {
1383 return (uint_t)(m_integer.zextOrTrunc(sizeof(uint_t) * 8)).getZExtValue();
1385 return (uint_t)m_float.convertToFloat();
1387 return (uint_t)m_float.convertToDouble();
1389 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1390 return (uint_t)(ldbl_val.zextOrTrunc(sizeof(uint_t) * 8)).getZExtValue();
1395 long Scalar::SLong(long fail_value) const {
1409 return (slong_t)(m_integer.sextOrTrunc(sizeof(slong_t) * 8)).getSExtValue();
1411 return (slong_t)m_float.convertToFloat();
1413 return (slong_t)m_float.convertToDouble();
1415 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1416 return (slong_t)(ldbl_val.sextOrTrunc(sizeof(slong_t) * 8)).getSExtValue();
1421 unsigned long Scalar::ULong(unsigned long fail_value) const {
1435 return (ulong_t)(m_integer.zextOrTrunc(sizeof(ulong_t) * 8)).getZExtValue();
1437 return (ulong_t)m_float.convertToFloat();
1439 return (ulong_t)m_float.convertToDouble();
1441 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1442 return (ulong_t)(ldbl_val.zextOrTrunc(sizeof(ulong_t) * 8)).getZExtValue();
1447 long long Scalar::SLongLong(long long fail_value) const {
1461 return (slonglong_t)(m_integer.sextOrTrunc(sizeof(slonglong_t) * 8))
1464 return (slonglong_t)m_float.convertToFloat();
1466 return (slonglong_t)m_float.convertToDouble();
1468 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1469 return (slonglong_t)(ldbl_val.sextOrTrunc(sizeof(slonglong_t) * 8))
1475 unsigned long long Scalar::ULongLong(unsigned long long fail_value) const {
1489 return (ulonglong_t)(m_integer.zextOrTrunc(sizeof(ulonglong_t) * 8))
1492 return (ulonglong_t)m_float.convertToFloat();
1494 return (ulonglong_t)m_float.convertToDouble();
1496 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1497 return (ulonglong_t)(ldbl_val.zextOrTrunc(sizeof(ulonglong_t) * 8))
1503 llvm::APInt Scalar::SInt128(llvm::APInt &fail_value) const {
1521 return m_float.bitcastToAPInt();
1526 llvm::APInt Scalar::UInt128(const llvm::APInt &fail_value) const {
1544 return m_float.bitcastToAPInt();
1549 llvm::APInt Scalar::SInt256(llvm::APInt &fail_value) const {
1567 return m_float.bitcastToAPInt();
1572 llvm::APInt Scalar::UInt256(const llvm::APInt &fail_value) const {
1590 return m_float.bitcastToAPInt();
1595 float Scalar::Float(float fail_value) const {
1609 return llvm::APIntOps::RoundAPIntToFloat(m_integer);
1611 return m_float.convertToFloat();
1613 return (float_t)m_float.convertToDouble();
1615 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1616 return ldbl_val.bitsToFloat();
1621 double Scalar::Double(double fail_value) const {
1635 return llvm::APIntOps::RoundAPIntToDouble(m_integer);
1637 return (double_t)m_float.convertToFloat();
1639 return m_float.convertToDouble();
1641 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1642 return ldbl_val.bitsToFloat();
1647 long double Scalar::LongDouble(long double fail_value) const {
1661 return (long_double_t)llvm::APIntOps::RoundAPIntToDouble(m_integer);
1663 return (long_double_t)m_float.convertToFloat();
1665 return (long_double_t)m_float.convertToDouble();
1667 llvm::APInt ldbl_val = m_float.bitcastToAPInt();
1668 return (long_double_t)ldbl_val.bitsToDouble();
1673 Scalar &Scalar::operator+=(const Scalar &rhs) {
1677 if ((m_type = PromoteToMaxType(*this, rhs, temp_value, a, b)) !=
1692 m_integer = a->m_integer + b->m_integer;
1698 m_float = a->m_float + b->m_float;
1705 Scalar &Scalar::operator<<=(const Scalar &rhs) {
1724 switch (rhs.m_type) {
1741 m_integer = m_integer << rhs.m_integer;
1749 bool Scalar::ShiftRightLogical(const Scalar &rhs) {
1768 switch (rhs.m_type) {
1785 m_integer = m_integer.lshr(rhs.m_integer);
1790 return m_type != e_void;
1793 Scalar &Scalar::operator>>=(const Scalar &rhs) {
1812 switch (rhs.m_type) {
1829 m_integer = m_integer.ashr(rhs.m_integer);
1837 Scalar &Scalar::operator&=(const Scalar &rhs) {
1856 switch (rhs.m_type) {
1873 m_integer &= rhs.m_integer;
1881 bool Scalar::AbsoluteValue() {
1891 if (m_integer.isNegative())
1892 m_integer = -m_integer;
1904 m_float.clearSign();
1910 bool Scalar::UnaryNegate() {
1924 m_integer = -m_integer;
1929 m_float.changeSign();
1935 bool Scalar::OnesComplement() {
1947 m_integer = ~m_integer;
1959 const Scalar lldb_private::operator+(const Scalar &lhs, const Scalar &rhs) {
1964 if ((result.m_type = PromoteToMaxType(lhs, rhs, temp_value, a, b)) !=
1966 switch (result.m_type) {
1967 case Scalar::e_void:
1969 case Scalar::e_sint:
1970 case Scalar::e_uint:
1971 case Scalar::e_slong:
1972 case Scalar::e_ulong:
1973 case Scalar::e_slonglong:
1974 case Scalar::e_ulonglong:
1975 case Scalar::e_sint128:
1976 case Scalar::e_uint128:
1977 case Scalar::e_sint256:
1978 case Scalar::e_uint256:
1979 result.m_integer = a->m_integer + b->m_integer;
1981 case Scalar::e_float:
1982 case Scalar::e_double:
1983 case Scalar::e_long_double:
1984 result.m_float = a->m_float + b->m_float;
1991 const Scalar lldb_private::operator-(const Scalar &lhs, const Scalar &rhs) {
1996 if ((result.m_type = PromoteToMaxType(lhs, rhs, temp_value, a, b)) !=
1998 switch (result.m_type) {
1999 case Scalar::e_void:
2001 case Scalar::e_sint:
2002 case Scalar::e_uint:
2003 case Scalar::e_slong:
2004 case Scalar::e_ulong:
2005 case Scalar::e_slonglong:
2006 case Scalar::e_ulonglong:
2007 case Scalar::e_sint128:
2008 case Scalar::e_uint128:
2009 case Scalar::e_sint256:
2010 case Scalar::e_uint256:
2011 result.m_integer = a->m_integer - b->m_integer;
2013 case Scalar::e_float:
2014 case Scalar::e_double:
2015 case Scalar::e_long_double:
2016 result.m_float = a->m_float - b->m_float;
2023 const Scalar lldb_private::operator/(const Scalar &lhs, const Scalar &rhs) {
2028 if ((result.m_type = PromoteToMaxType(lhs, rhs, temp_value, a, b)) !=
2030 switch (result.m_type) {
2031 case Scalar::e_void:
2033 case Scalar::e_sint:
2034 case Scalar::e_slong:
2035 case Scalar::e_slonglong:
2036 case Scalar::e_sint128:
2037 case Scalar::e_sint256:
2038 if (b->m_integer != 0) {
2039 result.m_integer = a->m_integer.sdiv(b->m_integer);
2043 case Scalar::e_uint:
2044 case Scalar::e_ulong:
2045 case Scalar::e_ulonglong:
2046 case Scalar::e_uint128:
2047 case Scalar::e_uint256:
2048 if (b->m_integer != 0) {
2049 result.m_integer = a->m_integer.udiv(b->m_integer);
2053 case Scalar::e_float:
2054 case Scalar::e_double:
2055 case Scalar::e_long_double:
2056 if (!b->m_float.isZero()) {
2057 result.m_float = a->m_float / b->m_float;
2063 // For division only, the only way it should make it here is if a promotion
2064 // failed, or if we are trying to do a divide by zero.
2065 result.m_type = Scalar::e_void;
2069 const Scalar lldb_private::operator*(const Scalar &lhs, const Scalar &rhs) {
2074 if ((result.m_type = PromoteToMaxType(lhs, rhs, temp_value, a, b)) !=
2076 switch (result.m_type) {
2077 case Scalar::e_void:
2079 case Scalar::e_sint:
2080 case Scalar::e_uint:
2081 case Scalar::e_slong:
2082 case Scalar::e_ulong:
2083 case Scalar::e_slonglong:
2084 case Scalar::e_ulonglong:
2085 case Scalar::e_sint128:
2086 case Scalar::e_uint128:
2087 case Scalar::e_sint256:
2088 case Scalar::e_uint256:
2089 result.m_integer = a->m_integer * b->m_integer;
2091 case Scalar::e_float:
2092 case Scalar::e_double:
2093 case Scalar::e_long_double:
2094 result.m_float = a->m_float * b->m_float;
2101 const Scalar lldb_private::operator&(const Scalar &lhs, const Scalar &rhs) {
2106 if ((result.m_type = PromoteToMaxType(lhs, rhs, temp_value, a, b)) !=
2108 switch (result.m_type) {
2109 case Scalar::e_sint:
2110 case Scalar::e_uint:
2111 case Scalar::e_slong:
2112 case Scalar::e_ulong:
2113 case Scalar::e_slonglong:
2114 case Scalar::e_ulonglong:
2115 case Scalar::e_sint128:
2116 case Scalar::e_uint128:
2117 case Scalar::e_sint256:
2118 case Scalar::e_uint256:
2119 result.m_integer = a->m_integer & b->m_integer;
2121 case Scalar::e_void:
2122 case Scalar::e_float:
2123 case Scalar::e_double:
2124 case Scalar::e_long_double:
2125 // No bitwise AND on floats, doubles of long doubles
2126 result.m_type = Scalar::e_void;
2133 const Scalar lldb_private::operator|(const Scalar &lhs, const Scalar &rhs) {
2138 if ((result.m_type = PromoteToMaxType(lhs, rhs, temp_value, a, b)) !=
2140 switch (result.m_type) {
2141 case Scalar::e_sint:
2142 case Scalar::e_uint:
2143 case Scalar::e_slong:
2144 case Scalar::e_ulong:
2145 case Scalar::e_slonglong:
2146 case Scalar::e_ulonglong:
2147 case Scalar::e_sint128:
2148 case Scalar::e_uint128:
2149 case Scalar::e_sint256:
2150 case Scalar::e_uint256:
2151 result.m_integer = a->m_integer | b->m_integer;
2154 case Scalar::e_void:
2155 case Scalar::e_float:
2156 case Scalar::e_double:
2157 case Scalar::e_long_double:
2158 // No bitwise AND on floats, doubles of long doubles
2159 result.m_type = Scalar::e_void;
2166 const Scalar lldb_private::operator%(const Scalar &lhs, const Scalar &rhs) {
2171 if ((result.m_type = PromoteToMaxType(lhs, rhs, temp_value, a, b)) !=
2173 switch (result.m_type) {
2176 case Scalar::e_void:
2178 case Scalar::e_sint:
2179 case Scalar::e_slong:
2180 case Scalar::e_slonglong:
2181 case Scalar::e_sint128:
2182 case Scalar::e_sint256:
2183 if (b->m_integer != 0) {
2184 result.m_integer = a->m_integer.srem(b->m_integer);
2188 case Scalar::e_uint:
2189 case Scalar::e_ulong:
2190 case Scalar::e_ulonglong:
2191 case Scalar::e_uint128:
2192 case Scalar::e_uint256:
2193 if (b->m_integer != 0) {
2194 result.m_integer = a->m_integer.urem(b->m_integer);
2200 result.m_type = Scalar::e_void;
2204 const Scalar lldb_private::operator^(const Scalar &lhs, const Scalar &rhs) {
2209 if ((result.m_type = PromoteToMaxType(lhs, rhs, temp_value, a, b)) !=
2211 switch (result.m_type) {
2212 case Scalar::e_sint:
2213 case Scalar::e_uint:
2214 case Scalar::e_slong:
2215 case Scalar::e_ulong:
2216 case Scalar::e_slonglong:
2217 case Scalar::e_ulonglong:
2218 case Scalar::e_sint128:
2219 case Scalar::e_uint128:
2220 case Scalar::e_sint256:
2221 case Scalar::e_uint256:
2222 result.m_integer = a->m_integer ^ b->m_integer;
2225 case Scalar::e_void:
2226 case Scalar::e_float:
2227 case Scalar::e_double:
2228 case Scalar::e_long_double:
2229 // No bitwise AND on floats, doubles of long doubles
2230 result.m_type = Scalar::e_void;
2237 const Scalar lldb_private::operator<<(const Scalar &lhs, const Scalar &rhs) {
2238 Scalar result = lhs;
2243 const Scalar lldb_private::operator>>(const Scalar &lhs, const Scalar &rhs) {
2244 Scalar result = lhs;
2249 Status Scalar::SetValueFromCString(const char *value_str, Encoding encoding,
2252 if (value_str == nullptr || value_str[0] == '\0') {
2253 error.SetErrorString("Invalid c-string value string.");
2257 case eEncodingInvalid:
2258 error.SetErrorString("Invalid encoding.");
2262 if (byte_size <= sizeof(uint64_t)) {
2264 if (!llvm::to_integer(value_str, uval64))
2265 error.SetErrorStringWithFormat(
2266 "'%s' is not a valid unsigned integer string value", value_str);
2267 else if (!UIntValueIsValidForSize(uval64, byte_size))
2268 error.SetErrorStringWithFormat("value 0x%" PRIx64
2269 " is too large to fit in a %" PRIu64
2270 " byte unsigned integer value",
2271 uval64, (uint64_t)byte_size);
2273 m_type = Scalar::GetValueTypeForUnsignedIntegerWithByteSize(byte_size);
2276 m_integer = llvm::APInt(sizeof(uint_t) * 8, uval64, false);
2279 m_integer = llvm::APInt(sizeof(ulong_t) * 8, uval64, false);
2282 m_integer = llvm::APInt(sizeof(ulonglong_t) * 8, uval64, false);
2285 error.SetErrorStringWithFormat(
2286 "unsupported unsigned integer byte size: %" PRIu64 "",
2287 (uint64_t)byte_size);
2292 error.SetErrorStringWithFormat(
2293 "unsupported unsigned integer byte size: %" PRIu64 "",
2294 (uint64_t)byte_size);
2300 if (byte_size <= sizeof(int64_t)) {
2302 if (!llvm::to_integer(value_str, sval64))
2303 error.SetErrorStringWithFormat(
2304 "'%s' is not a valid signed integer string value", value_str);
2305 else if (!SIntValueIsValidForSize(sval64, byte_size))
2306 error.SetErrorStringWithFormat("value 0x%" PRIx64
2307 " is too large to fit in a %" PRIu64
2308 " byte signed integer value",
2309 sval64, (uint64_t)byte_size);
2311 m_type = Scalar::GetValueTypeForSignedIntegerWithByteSize(byte_size);
2314 m_integer = llvm::APInt(sizeof(sint_t) * 8, sval64, true);
2317 m_integer = llvm::APInt(sizeof(slong_t) * 8, sval64, true);
2320 m_integer = llvm::APInt(sizeof(slonglong_t) * 8, sval64, true);
2323 error.SetErrorStringWithFormat(
2324 "unsupported signed integer byte size: %" PRIu64 "",
2325 (uint64_t)byte_size);
2330 error.SetErrorStringWithFormat(
2331 "unsupported signed integer byte size: %" PRIu64 "",
2332 (uint64_t)byte_size);
2337 case eEncodingIEEE754:
2339 static double d_val;
2340 static long double l_val;
2341 if (byte_size == sizeof(float)) {
2342 if (::sscanf(value_str, "%f", &f_val) == 1) {
2343 m_float = llvm::APFloat(f_val);
2346 error.SetErrorStringWithFormat("'%s' is not a valid float string value",
2348 } else if (byte_size == sizeof(double)) {
2349 if (::sscanf(value_str, "%lf", &d_val) == 1) {
2350 m_float = llvm::APFloat(d_val);
2353 error.SetErrorStringWithFormat("'%s' is not a valid float string value",
2355 } else if (byte_size == sizeof(long double)) {
2356 if (::sscanf(value_str, "%Lf", &l_val) == 1) {
2358 llvm::APFloat(llvm::APFloat::x87DoubleExtended(),
2359 llvm::APInt(BITWIDTH_INT128, NUM_OF_WORDS_INT128,
2360 ((type128 *)&l_val)->x));
2361 m_type = e_long_double;
2363 error.SetErrorStringWithFormat("'%s' is not a valid float string value",
2366 error.SetErrorStringWithFormat("unsupported float byte size: %" PRIu64 "",
2367 (uint64_t)byte_size);
2372 case eEncodingVector:
2373 error.SetErrorString("vector encoding unsupported.");
2382 Status Scalar::SetValueFromData(DataExtractor &data, lldb::Encoding encoding,
2389 case lldb::eEncodingInvalid:
2390 error.SetErrorString("invalid encoding");
2392 case lldb::eEncodingVector:
2393 error.SetErrorString("vector encoding unsupported");
2395 case lldb::eEncodingUint: {
2396 lldb::offset_t offset = 0;
2398 switch (byte_size) {
2400 operator=((uint8_t)data.GetU8(&offset));
2403 operator=((uint16_t)data.GetU16(&offset));
2406 operator=((uint32_t)data.GetU32(&offset));
2409 operator=((uint64_t)data.GetU64(&offset));
2412 if (data.GetByteOrder() == eByteOrderBig) {
2413 int128.x[1] = (uint64_t)data.GetU64(&offset);
2414 int128.x[0] = (uint64_t)data.GetU64(&offset);
2416 int128.x[0] = (uint64_t)data.GetU64(&offset);
2417 int128.x[1] = (uint64_t)data.GetU64(&offset);
2419 operator=(llvm::APInt(BITWIDTH_INT128, NUM_OF_WORDS_INT128, int128.x));
2422 if (data.GetByteOrder() == eByteOrderBig) {
2423 int256.x[3] = (uint64_t)data.GetU64(&offset);
2424 int256.x[2] = (uint64_t)data.GetU64(&offset);
2425 int256.x[1] = (uint64_t)data.GetU64(&offset);
2426 int256.x[0] = (uint64_t)data.GetU64(&offset);
2428 int256.x[0] = (uint64_t)data.GetU64(&offset);
2429 int256.x[1] = (uint64_t)data.GetU64(&offset);
2430 int256.x[2] = (uint64_t)data.GetU64(&offset);
2431 int256.x[3] = (uint64_t)data.GetU64(&offset);
2433 operator=(llvm::APInt(BITWIDTH_INT256, NUM_OF_WORDS_INT256, int256.x));
2436 error.SetErrorStringWithFormat(
2437 "unsupported unsigned integer byte size: %" PRIu64 "",
2438 (uint64_t)byte_size);
2442 case lldb::eEncodingSint: {
2443 lldb::offset_t offset = 0;
2445 switch (byte_size) {
2447 operator=((int8_t)data.GetU8(&offset));
2450 operator=((int16_t)data.GetU16(&offset));
2453 operator=((int32_t)data.GetU32(&offset));
2456 operator=((int64_t)data.GetU64(&offset));
2459 if (data.GetByteOrder() == eByteOrderBig) {
2460 int128.x[1] = (uint64_t)data.GetU64(&offset);
2461 int128.x[0] = (uint64_t)data.GetU64(&offset);
2463 int128.x[0] = (uint64_t)data.GetU64(&offset);
2464 int128.x[1] = (uint64_t)data.GetU64(&offset);
2466 operator=(llvm::APInt(BITWIDTH_INT128, NUM_OF_WORDS_INT128, int128.x));
2469 if (data.GetByteOrder() == eByteOrderBig) {
2470 int256.x[3] = (uint64_t)data.GetU64(&offset);
2471 int256.x[2] = (uint64_t)data.GetU64(&offset);
2472 int256.x[1] = (uint64_t)data.GetU64(&offset);
2473 int256.x[0] = (uint64_t)data.GetU64(&offset);
2475 int256.x[0] = (uint64_t)data.GetU64(&offset);
2476 int256.x[1] = (uint64_t)data.GetU64(&offset);
2477 int256.x[2] = (uint64_t)data.GetU64(&offset);
2478 int256.x[3] = (uint64_t)data.GetU64(&offset);
2480 operator=(llvm::APInt(BITWIDTH_INT256, NUM_OF_WORDS_INT256, int256.x));
2483 error.SetErrorStringWithFormat(
2484 "unsupported signed integer byte size: %" PRIu64 "",
2485 (uint64_t)byte_size);
2489 case lldb::eEncodingIEEE754: {
2490 lldb::offset_t offset = 0;
2492 if (byte_size == sizeof(float))
2493 operator=((float)data.GetFloat(&offset));
2494 else if (byte_size == sizeof(double))
2495 operator=((double)data.GetDouble(&offset));
2496 else if (byte_size == sizeof(long double))
2497 operator=((long double)data.GetLongDouble(&offset));
2499 error.SetErrorStringWithFormat("unsupported float byte size: %" PRIu64 "",
2500 (uint64_t)byte_size);
2507 bool Scalar::SignExtend(uint32_t sign_bit_pos) {
2508 const uint32_t max_bit_pos = GetByteSize() * 8;
2510 if (sign_bit_pos < max_bit_pos) {
2512 case Scalar::e_void:
2513 case Scalar::e_float:
2514 case Scalar::e_double:
2515 case Scalar::e_long_double:
2518 case Scalar::e_sint:
2519 case Scalar::e_uint:
2520 case Scalar::e_slong:
2521 case Scalar::e_ulong:
2522 case Scalar::e_slonglong:
2523 case Scalar::e_ulonglong:
2524 case Scalar::e_sint128:
2525 case Scalar::e_uint128:
2526 case Scalar::e_sint256:
2527 case Scalar::e_uint256:
2528 if (max_bit_pos == sign_bit_pos)
2530 else if (sign_bit_pos < (max_bit_pos - 1)) {
2531 llvm::APInt sign_bit = llvm::APInt::getSignMask(sign_bit_pos + 1);
2532 llvm::APInt bitwize_and = m_integer & sign_bit;
2533 if (bitwize_and.getBoolValue()) {
2534 const llvm::APInt mask =
2535 ~(sign_bit) + llvm::APInt(m_integer.getBitWidth(), 1);
2546 size_t Scalar::GetAsMemoryData(void *dst, size_t dst_len,
2547 lldb::ByteOrder dst_byte_order,
2548 Status &error) const {
2549 // Get a data extractor that points to the native scalar data
2551 if (!GetData(data)) {
2552 error.SetErrorString("invalid scalar value");
2556 const size_t src_len = data.GetByteSize();
2558 // Prepare a memory buffer that contains some or all of the register value
2559 const size_t bytes_copied =
2560 data.CopyByteOrderedData(0, // src offset
2561 src_len, // src length
2563 dst_len, // dst length
2564 dst_byte_order); // dst byte order
2565 if (bytes_copied == 0)
2566 error.SetErrorString("failed to copy data");
2568 return bytes_copied;
2571 bool Scalar::ExtractBitfield(uint32_t bit_size, uint32_t bit_offset) {
2576 case Scalar::e_void:
2577 case Scalar::e_float:
2578 case Scalar::e_double:
2579 case Scalar::e_long_double:
2582 case Scalar::e_sint:
2583 case Scalar::e_slong:
2584 case Scalar::e_slonglong:
2585 case Scalar::e_sint128:
2586 case Scalar::e_sint256:
2587 m_integer = m_integer.ashr(bit_offset)
2588 .sextOrTrunc(bit_size)
2589 .sextOrSelf(8 * GetByteSize());
2592 case Scalar::e_uint:
2593 case Scalar::e_ulong:
2594 case Scalar::e_ulonglong:
2595 case Scalar::e_uint128:
2596 case Scalar::e_uint256:
2597 m_integer = m_integer.lshr(bit_offset)
2598 .zextOrTrunc(bit_size)
2599 .zextOrSelf(8 * GetByteSize());
2605 bool lldb_private::operator==(const Scalar &lhs, const Scalar &rhs) {
2606 // If either entry is void then we can just compare the types
2607 if (lhs.m_type == Scalar::e_void || rhs.m_type == Scalar::e_void)
2608 return lhs.m_type == rhs.m_type;
2613 llvm::APFloat::cmpResult result;
2614 switch (PromoteToMaxType(lhs, rhs, temp_value, a, b)) {
2615 case Scalar::e_void:
2617 case Scalar::e_sint:
2618 case Scalar::e_uint:
2619 case Scalar::e_slong:
2620 case Scalar::e_ulong:
2621 case Scalar::e_slonglong:
2622 case Scalar::e_ulonglong:
2623 case Scalar::e_sint128:
2624 case Scalar::e_uint128:
2625 case Scalar::e_sint256:
2626 case Scalar::e_uint256:
2627 return a->m_integer == b->m_integer;
2628 case Scalar::e_float:
2629 case Scalar::e_double:
2630 case Scalar::e_long_double:
2631 result = a->m_float.compare(b->m_float);
2632 if (result == llvm::APFloat::cmpEqual)
2638 bool lldb_private::operator!=(const Scalar &lhs, const Scalar &rhs) {
2639 // If either entry is void then we can just compare the types
2640 if (lhs.m_type == Scalar::e_void || rhs.m_type == Scalar::e_void)
2641 return lhs.m_type != rhs.m_type;
2644 temp_value; // A temp value that might get a copy of either promoted value
2647 llvm::APFloat::cmpResult result;
2648 switch (PromoteToMaxType(lhs, rhs, temp_value, a, b)) {
2649 case Scalar::e_void:
2651 case Scalar::e_sint:
2652 case Scalar::e_uint:
2653 case Scalar::e_slong:
2654 case Scalar::e_ulong:
2655 case Scalar::e_slonglong:
2656 case Scalar::e_ulonglong:
2657 case Scalar::e_sint128:
2658 case Scalar::e_uint128:
2659 case Scalar::e_sint256:
2660 case Scalar::e_uint256:
2661 return a->m_integer != b->m_integer;
2662 case Scalar::e_float:
2663 case Scalar::e_double:
2664 case Scalar::e_long_double:
2665 result = a->m_float.compare(b->m_float);
2666 if (result != llvm::APFloat::cmpEqual)
2672 bool lldb_private::operator<(const Scalar &lhs, const Scalar &rhs) {
2673 if (lhs.m_type == Scalar::e_void || rhs.m_type == Scalar::e_void)
2679 llvm::APFloat::cmpResult result;
2680 switch (PromoteToMaxType(lhs, rhs, temp_value, a, b)) {
2681 case Scalar::e_void:
2683 case Scalar::e_sint:
2684 case Scalar::e_slong:
2685 case Scalar::e_slonglong:
2686 case Scalar::e_sint128:
2687 case Scalar::e_sint256:
2688 return a->m_integer.slt(b->m_integer);
2689 case Scalar::e_uint:
2690 case Scalar::e_ulong:
2691 case Scalar::e_ulonglong:
2692 case Scalar::e_uint128:
2693 case Scalar::e_uint256:
2694 return a->m_integer.ult(b->m_integer);
2695 case Scalar::e_float:
2696 case Scalar::e_double:
2697 case Scalar::e_long_double:
2698 result = a->m_float.compare(b->m_float);
2699 if (result == llvm::APFloat::cmpLessThan)
2705 bool lldb_private::operator<=(const Scalar &lhs, const Scalar &rhs) {
2706 if (lhs.m_type == Scalar::e_void || rhs.m_type == Scalar::e_void)
2712 llvm::APFloat::cmpResult result;
2713 switch (PromoteToMaxType(lhs, rhs, temp_value, a, b)) {
2714 case Scalar::e_void:
2716 case Scalar::e_sint:
2717 case Scalar::e_slong:
2718 case Scalar::e_slonglong:
2719 case Scalar::e_sint128:
2720 case Scalar::e_sint256:
2721 return a->m_integer.sle(b->m_integer);
2722 case Scalar::e_uint:
2723 case Scalar::e_ulong:
2724 case Scalar::e_ulonglong:
2725 case Scalar::e_uint128:
2726 case Scalar::e_uint256:
2727 return a->m_integer.ule(b->m_integer);
2728 case Scalar::e_float:
2729 case Scalar::e_double:
2730 case Scalar::e_long_double:
2731 result = a->m_float.compare(b->m_float);
2732 if (result == llvm::APFloat::cmpLessThan ||
2733 result == llvm::APFloat::cmpEqual)
2739 bool lldb_private::operator>(const Scalar &lhs, const Scalar &rhs) {
2740 if (lhs.m_type == Scalar::e_void || rhs.m_type == Scalar::e_void)
2746 llvm::APFloat::cmpResult result;
2747 switch (PromoteToMaxType(lhs, rhs, temp_value, a, b)) {
2748 case Scalar::e_void:
2750 case Scalar::e_sint:
2751 case Scalar::e_slong:
2752 case Scalar::e_slonglong:
2753 case Scalar::e_sint128:
2754 case Scalar::e_sint256:
2755 return a->m_integer.sgt(b->m_integer);
2756 case Scalar::e_uint:
2757 case Scalar::e_ulong:
2758 case Scalar::e_ulonglong:
2759 case Scalar::e_uint128:
2760 case Scalar::e_uint256:
2761 return a->m_integer.ugt(b->m_integer);
2762 case Scalar::e_float:
2763 case Scalar::e_double:
2764 case Scalar::e_long_double:
2765 result = a->m_float.compare(b->m_float);
2766 if (result == llvm::APFloat::cmpGreaterThan)
2772 bool lldb_private::operator>=(const Scalar &lhs, const Scalar &rhs) {
2773 if (lhs.m_type == Scalar::e_void || rhs.m_type == Scalar::e_void)
2779 llvm::APFloat::cmpResult result;
2780 switch (PromoteToMaxType(lhs, rhs, temp_value, a, b)) {
2781 case Scalar::e_void:
2783 case Scalar::e_sint:
2784 case Scalar::e_slong:
2785 case Scalar::e_slonglong:
2786 case Scalar::e_sint128:
2787 case Scalar::e_sint256:
2788 return a->m_integer.sge(b->m_integer);
2789 case Scalar::e_uint:
2790 case Scalar::e_ulong:
2791 case Scalar::e_ulonglong:
2792 case Scalar::e_uint128:
2793 case Scalar::e_uint256:
2794 return a->m_integer.uge(b->m_integer);
2795 case Scalar::e_float:
2796 case Scalar::e_double:
2797 case Scalar::e_long_double:
2798 result = a->m_float.compare(b->m_float);
2799 if (result == llvm::APFloat::cmpGreaterThan ||
2800 result == llvm::APFloat::cmpEqual)
2806 bool Scalar::ClearBit(uint32_t bit) {
2820 m_integer.clearBit(bit);
2830 bool Scalar::SetBit(uint32_t bit) {
2844 m_integer.setBit(bit);