shafik created this revision.
shafik added reviewers: aprantl, jingham, vsk.
shafik requested review of this revision.
Herald added a reviewer: jdoerfert.
Herald added a subscriber: sstefan1.

When bit-field data was stored in a `Scalar` in `ValueObjectChild` during 
`UpdateValue()` it was extracting the bit-field value. Later on in 
`lldb_private::DumpDataExtractor(…)` we were again attempting to extract the 
bit-field:

  s->Printf("%" PRIu64,
              DE.GetMaxU64Bitfield(&offset, item_byte_size, item_bit_size,
                                   item_bit_offset));

which would then not obtain the correct value. This will remove the extra 
extraction in `UpdateValue()`.

We hit this specific case when values are passed in registers, which we could 
only reproduce in an optimized build.


https://reviews.llvm.org/D85376

Files:
  lldb/source/Core/ValueObjectChild.cpp
  lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/Makefile
  
lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/TestValueObjPassByRef.py
  lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/main.s

Index: lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/main.s
===================================================================
--- /dev/null
+++ lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/main.s
@@ -0,0 +1,653 @@
+## This was generated from the following code:
+##
+## We are testing how ValueObject deals with bit-fields when an argument is
+## passed by register. Compiling at -O1 allows us to capture this case and
+## test it.
+##
+## #include <stdint.h>
+## #include <stdio.h>
+##
+## typedef union
+## {
+##  uint32_t raw;
+##  struct
+##  {
+##    uint32_t a : 8;
+##    uint32_t b : 8;
+##    uint32_t c : 6;
+##    uint32_t d : 2;
+##    uint32_t e : 6;
+##    uint32_t f : 2;
+##  } ;
+## } U;
+##
+## void f(U u) {
+##   printf( "%d\n", u.raw);
+##   return;
+## }
+##
+## int main() {
+##   U u;
+##   u.raw = 0x64A40101;
+##
+##   f(u);
+## }
+##
+## Compiled as follows:
+##
+##
+## clang -g -O1 main.c  -o main
+## clang -g -O1 main.c -S -o main.s
+##
+	.section	__TEXT,__text,regular,pure_instructions
+	.build_version macos, 10, 15	sdk_version 10, 15
+	.globl	_f                      ## -- Begin function f
+	.p2align	4, 0x90
+_f:                                     ## @f
+Lfunc_begin0:
+	.file	1 "/Users/shafik/code" "main.c"
+	.loc	1 18 0                  ## main.c:18:0
+	.cfi_startproc
+## %bb.0:
+	pushq	%rbp
+	.cfi_def_cfa_offset 16
+	.cfi_offset %rbp, -16
+	movq	%rsp, %rbp
+	.cfi_def_cfa_register %rbp
+	##DEBUG_VALUE: f:u <- $edi
+	movl	%edi, %esi
+Ltmp0:
+	##DEBUG_VALUE: f:u <- $esi
+	.loc	1 19 3 prologue_end     ## main.c:19:3
+	leaq	L_.str(%rip), %rdi
+	##DEBUG_VALUE: f:u <- $esi
+	xorl	%eax, %eax
+	popq	%rbp
+	jmp	_printf                 ## TAILCALL
+Ltmp1:
+Lfunc_end0:
+	.cfi_endproc
+                                        ## -- End function
+	.globl	_main                   ## -- Begin function main
+	.p2align	4, 0x90
+_main:                                  ## @main
+Lfunc_begin1:
+	.loc	1 23 0                  ## main.c:23:0
+	.cfi_startproc
+## %bb.0:
+	pushq	%rbp
+	.cfi_def_cfa_offset 16
+	.cfi_offset %rbp, -16
+	movq	%rsp, %rbp
+	.cfi_def_cfa_register %rbp
+Ltmp2:
+	##DEBUG_VALUE: main:u <- 1688469761
+	.loc	1 27 3 prologue_end     ## main.c:27:3
+	movl	$1688469761, %edi       ## imm = 0x64A40101
+	callq	_f
+Ltmp3:
+	.loc	1 28 1                  ## main.c:28:1
+	xorl	%eax, %eax
+	popq	%rbp
+	retq
+Ltmp4:
+Lfunc_end1:
+	.cfi_endproc
+                                        ## -- End function
+	.section	__TEXT,__cstring,cstring_literals
+L_.str:                                 ## @.str
+	.asciz	"%d\n"
+
+	.file	2 "/Applications/Xcode5.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.15.sdk/usr/include/_types" "_uint32_t.h"
+	.section	__DWARF,__debug_str,regular,debug
+Linfo_string:
+	.asciz	"Apple clang version 11.0.0 (clang-1100.0.31.5)" ## string offset=0
+	.asciz	"main.c"                ## string offset=47
+	.asciz	"/Users/shafik/code"    ## string offset=54
+	.asciz	"f"                     ## string offset=73
+	.asciz	"main"                  ## string offset=75
+	.asciz	"int"                   ## string offset=80
+	.asciz	"u"                     ## string offset=84
+	.asciz	"U"                     ## string offset=86
+	.asciz	"raw"                   ## string offset=88
+	.asciz	"uint32_t"              ## string offset=92
+	.asciz	"unsigned int"          ## string offset=101
+	.asciz	"a"                     ## string offset=114
+	.asciz	"b"                     ## string offset=116
+	.asciz	"c"                     ## string offset=118
+	.asciz	"d"                     ## string offset=120
+	.asciz	"e"                     ## string offset=122
+	.section	__DWARF,__debug_loc,regular,debug
+Lsection_debug_loc:
+Ldebug_loc0:
+.set Lset0, Lfunc_begin0-Lfunc_begin0
+	.quad	Lset0
+.set Lset1, Ltmp0-Lfunc_begin0
+	.quad	Lset1
+	.short	1                       ## Loc expr size
+	.byte	85                      ## super-register DW_OP_reg5
+.set Lset2, Ltmp0-Lfunc_begin0
+	.quad	Lset2
+.set Lset3, Ltmp1-Lfunc_begin0
+	.quad	Lset3
+	.short	1                       ## Loc expr size
+	.byte	84                      ## super-register DW_OP_reg4
+	.quad	0
+	.quad	0
+	.section	__DWARF,__debug_abbrev,regular,debug
+Lsection_abbrev:
+	.byte	1                       ## Abbreviation Code
+	.byte	17                      ## DW_TAG_compile_unit
+	.byte	1                       ## DW_CHILDREN_yes
+	.byte	37                      ## DW_AT_producer
+	.byte	14                      ## DW_FORM_strp
+	.byte	19                      ## DW_AT_language
+	.byte	5                       ## DW_FORM_data2
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	16                      ## DW_AT_stmt_list
+	.byte	23                      ## DW_FORM_sec_offset
+	.byte	27                      ## DW_AT_comp_dir
+	.byte	14                      ## DW_FORM_strp
+	.ascii	"\264B"                 ## DW_AT_GNU_pubnames
+	.byte	25                      ## DW_FORM_flag_present
+	.ascii	"\341\177"              ## DW_AT_APPLE_optimized
+	.byte	25                      ## DW_FORM_flag_present
+	.byte	17                      ## DW_AT_low_pc
+	.byte	1                       ## DW_FORM_addr
+	.byte	18                      ## DW_AT_high_pc
+	.byte	6                       ## DW_FORM_data4
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	2                       ## Abbreviation Code
+	.byte	46                      ## DW_TAG_subprogram
+	.byte	1                       ## DW_CHILDREN_yes
+	.byte	17                      ## DW_AT_low_pc
+	.byte	1                       ## DW_FORM_addr
+	.byte	18                      ## DW_AT_high_pc
+	.byte	6                       ## DW_FORM_data4
+	.byte	64                      ## DW_AT_frame_base
+	.byte	24                      ## DW_FORM_exprloc
+	.byte	122                     ## DW_AT_call_all_calls
+	.byte	25                      ## DW_FORM_flag_present
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	39                      ## DW_AT_prototyped
+	.byte	25                      ## DW_FORM_flag_present
+	.byte	63                      ## DW_AT_external
+	.byte	25                      ## DW_FORM_flag_present
+	.ascii	"\341\177"              ## DW_AT_APPLE_optimized
+	.byte	25                      ## DW_FORM_flag_present
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	3                       ## Abbreviation Code
+	.byte	5                       ## DW_TAG_formal_parameter
+	.byte	0                       ## DW_CHILDREN_no
+	.byte	2                       ## DW_AT_location
+	.byte	23                      ## DW_FORM_sec_offset
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	73                      ## DW_AT_type
+	.byte	19                      ## DW_FORM_ref4
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	4                       ## Abbreviation Code
+	.byte	46                      ## DW_TAG_subprogram
+	.byte	1                       ## DW_CHILDREN_yes
+	.byte	17                      ## DW_AT_low_pc
+	.byte	1                       ## DW_FORM_addr
+	.byte	18                      ## DW_AT_high_pc
+	.byte	6                       ## DW_FORM_data4
+	.byte	64                      ## DW_AT_frame_base
+	.byte	24                      ## DW_FORM_exprloc
+	.byte	122                     ## DW_AT_call_all_calls
+	.byte	25                      ## DW_FORM_flag_present
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	73                      ## DW_AT_type
+	.byte	19                      ## DW_FORM_ref4
+	.byte	63                      ## DW_AT_external
+	.byte	25                      ## DW_FORM_flag_present
+	.ascii	"\341\177"              ## DW_AT_APPLE_optimized
+	.byte	25                      ## DW_FORM_flag_present
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	5                       ## Abbreviation Code
+	.byte	52                      ## DW_TAG_variable
+	.byte	0                       ## DW_CHILDREN_no
+	.byte	28                      ## DW_AT_const_value
+	.byte	15                      ## DW_FORM_udata
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	73                      ## DW_AT_type
+	.byte	19                      ## DW_FORM_ref4
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	6                       ## Abbreviation Code
+	.byte	72                      ## DW_TAG_call_site
+	.byte	0                       ## DW_CHILDREN_no
+	.byte	127                     ## DW_AT_call_origin
+	.byte	19                      ## DW_FORM_ref4
+	.byte	125                     ## DW_AT_call_return_pc
+	.byte	1                       ## DW_FORM_addr
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	7                       ## Abbreviation Code
+	.byte	36                      ## DW_TAG_base_type
+	.byte	0                       ## DW_CHILDREN_no
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	62                      ## DW_AT_encoding
+	.byte	11                      ## DW_FORM_data1
+	.byte	11                      ## DW_AT_byte_size
+	.byte	11                      ## DW_FORM_data1
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	8                       ## Abbreviation Code
+	.byte	22                      ## DW_TAG_typedef
+	.byte	0                       ## DW_CHILDREN_no
+	.byte	73                      ## DW_AT_type
+	.byte	19                      ## DW_FORM_ref4
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	9                       ## Abbreviation Code
+	.byte	23                      ## DW_TAG_union_type
+	.byte	1                       ## DW_CHILDREN_yes
+	.byte	11                      ## DW_AT_byte_size
+	.byte	11                      ## DW_FORM_data1
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	10                      ## Abbreviation Code
+	.byte	13                      ## DW_TAG_member
+	.byte	0                       ## DW_CHILDREN_no
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	73                      ## DW_AT_type
+	.byte	19                      ## DW_FORM_ref4
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	56                      ## DW_AT_data_member_location
+	.byte	11                      ## DW_FORM_data1
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	11                      ## Abbreviation Code
+	.byte	13                      ## DW_TAG_member
+	.byte	0                       ## DW_CHILDREN_no
+	.byte	73                      ## DW_AT_type
+	.byte	19                      ## DW_FORM_ref4
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	56                      ## DW_AT_data_member_location
+	.byte	11                      ## DW_FORM_data1
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	12                      ## Abbreviation Code
+	.byte	19                      ## DW_TAG_structure_type
+	.byte	1                       ## DW_CHILDREN_yes
+	.byte	11                      ## DW_AT_byte_size
+	.byte	11                      ## DW_FORM_data1
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	13                      ## Abbreviation Code
+	.byte	13                      ## DW_TAG_member
+	.byte	0                       ## DW_CHILDREN_no
+	.byte	3                       ## DW_AT_name
+	.byte	14                      ## DW_FORM_strp
+	.byte	73                      ## DW_AT_type
+	.byte	19                      ## DW_FORM_ref4
+	.byte	58                      ## DW_AT_decl_file
+	.byte	11                      ## DW_FORM_data1
+	.byte	59                      ## DW_AT_decl_line
+	.byte	11                      ## DW_FORM_data1
+	.byte	13                      ## DW_AT_bit_size
+	.byte	11                      ## DW_FORM_data1
+	.byte	107                     ## DW_AT_data_bit_offset
+	.byte	11                      ## DW_FORM_data1
+	.byte	0                       ## EOM(1)
+	.byte	0                       ## EOM(2)
+	.byte	0                       ## EOM(3)
+	.section	__DWARF,__debug_info,regular,debug
+Lsection_info:
+Lcu_begin0:
+.set Lset4, Ldebug_info_end0-Ldebug_info_start0 ## Length of Unit
+	.long	Lset4
+Ldebug_info_start0:
+	.short	4                       ## DWARF version number
+.set Lset5, Lsection_abbrev-Lsection_abbrev ## Offset Into Abbrev. Section
+	.long	Lset5
+	.byte	8                       ## Address Size (in bytes)
+	.byte	1                       ## Abbrev [1] 0xb:0x10c DW_TAG_compile_unit
+	.long	0                       ## DW_AT_producer
+	.short	12                      ## DW_AT_language
+	.long	47                      ## DW_AT_name
+.set Lset6, Lline_table_start0-Lsection_line ## DW_AT_stmt_list
+	.long	Lset6
+	.long	54                      ## DW_AT_comp_dir
+                                        ## DW_AT_GNU_pubnames
+                                        ## DW_AT_APPLE_optimized
+	.quad	Lfunc_begin0            ## DW_AT_low_pc
+.set Lset7, Lfunc_end1-Lfunc_begin0     ## DW_AT_high_pc
+	.long	Lset7
+	.byte	2                       ## Abbrev [2] 0x2a:0x25 DW_TAG_subprogram
+	.quad	Lfunc_begin0            ## DW_AT_low_pc
+.set Lset8, Lfunc_end0-Lfunc_begin0     ## DW_AT_high_pc
+	.long	Lset8
+	.byte	1                       ## DW_AT_frame_base
+	.byte	86
+                                        ## DW_AT_call_all_calls
+	.long	73                      ## DW_AT_name
+	.byte	1                       ## DW_AT_decl_file
+	.byte	18                      ## DW_AT_decl_line
+                                        ## DW_AT_prototyped
+                                        ## DW_AT_external
+                                        ## DW_AT_APPLE_optimized
+	.byte	3                       ## Abbrev [3] 0x3f:0xf DW_TAG_formal_parameter
+.set Lset9, Ldebug_loc0-Lsection_debug_loc ## DW_AT_location
+	.long	Lset9
+	.long	84                      ## DW_AT_name
+	.byte	1                       ## DW_AT_decl_file
+	.byte	18                      ## DW_AT_decl_line
+	.long	141                     ## DW_AT_type
+	.byte	0                       ## End Of Children Mark
+	.byte	4                       ## Abbrev [4] 0x4f:0x37 DW_TAG_subprogram
+	.quad	Lfunc_begin1            ## DW_AT_low_pc
+.set Lset10, Lfunc_end1-Lfunc_begin1    ## DW_AT_high_pc
+	.long	Lset10
+	.byte	1                       ## DW_AT_frame_base
+	.byte	86
+                                        ## DW_AT_call_all_calls
+	.long	75                      ## DW_AT_name
+	.byte	1                       ## DW_AT_decl_file
+	.byte	23                      ## DW_AT_decl_line
+	.long	134                     ## DW_AT_type
+                                        ## DW_AT_external
+                                        ## DW_AT_APPLE_optimized
+	.byte	5                       ## Abbrev [5] 0x68:0x10 DW_TAG_variable
+	.ascii	"\201\202\220\245\006"  ## DW_AT_const_value
+	.long	84                      ## DW_AT_name
+	.byte	1                       ## DW_AT_decl_file
+	.byte	24                      ## DW_AT_decl_line
+	.long	141                     ## DW_AT_type
+	.byte	6                       ## Abbrev [6] 0x78:0xd DW_TAG_call_site
+	.long	42                      ## DW_AT_call_origin
+	.quad	Ltmp3-Lfunc_begin1      ## DW_AT_call_return_pc
+	.byte	0                       ## End Of Children Mark
+	.byte	7                       ## Abbrev [7] 0x86:0x7 DW_TAG_base_type
+	.long	80                      ## DW_AT_name
+	.byte	5                       ## DW_AT_encoding
+	.byte	4                       ## DW_AT_byte_size
+	.byte	8                       ## Abbrev [8] 0x8d:0xb DW_TAG_typedef
+	.long	152                     ## DW_AT_type
+	.long	86                      ## DW_AT_name
+	.byte	1                       ## DW_AT_decl_file
+	.byte	16                      ## DW_AT_decl_line
+	.byte	9                       ## Abbrev [9] 0x98:0x6c DW_TAG_union_type
+	.byte	4                       ## DW_AT_byte_size
+	.byte	1                       ## DW_AT_decl_file
+	.byte	4                       ## DW_AT_decl_line
+	.byte	10                      ## Abbrev [10] 0x9c:0xc DW_TAG_member
+	.long	88                      ## DW_AT_name
+	.long	260                     ## DW_AT_type
+	.byte	1                       ## DW_AT_decl_file
+	.byte	6                       ## DW_AT_decl_line
+	.byte	0                       ## DW_AT_data_member_location
+	.byte	11                      ## Abbrev [11] 0xa8:0x8 DW_TAG_member
+	.long	176                     ## DW_AT_type
+	.byte	1                       ## DW_AT_decl_file
+	.byte	7                       ## DW_AT_decl_line
+	.byte	0                       ## DW_AT_data_member_location
+	.byte	12                      ## Abbrev [12] 0xb0:0x53 DW_TAG_structure_type
+	.byte	4                       ## DW_AT_byte_size
+	.byte	1                       ## DW_AT_decl_file
+	.byte	7                       ## DW_AT_decl_line
+	.byte	13                      ## Abbrev [13] 0xb4:0xd DW_TAG_member
+	.long	114                     ## DW_AT_name
+	.long	260                     ## DW_AT_type
+	.byte	1                       ## DW_AT_decl_file
+	.byte	9                       ## DW_AT_decl_line
+	.byte	8                       ## DW_AT_bit_size
+	.byte	0                       ## DW_AT_data_bit_offset
+	.byte	13                      ## Abbrev [13] 0xc1:0xd DW_TAG_member
+	.long	116                     ## DW_AT_name
+	.long	260                     ## DW_AT_type
+	.byte	1                       ## DW_AT_decl_file
+	.byte	10                      ## DW_AT_decl_line
+	.byte	8                       ## DW_AT_bit_size
+	.byte	8                       ## DW_AT_data_bit_offset
+	.byte	13                      ## Abbrev [13] 0xce:0xd DW_TAG_member
+	.long	118                     ## DW_AT_name
+	.long	260                     ## DW_AT_type
+	.byte	1                       ## DW_AT_decl_file
+	.byte	11                      ## DW_AT_decl_line
+	.byte	6                       ## DW_AT_bit_size
+	.byte	16                      ## DW_AT_data_bit_offset
+	.byte	13                      ## Abbrev [13] 0xdb:0xd DW_TAG_member
+	.long	120                     ## DW_AT_name
+	.long	260                     ## DW_AT_type
+	.byte	1                       ## DW_AT_decl_file
+	.byte	12                      ## DW_AT_decl_line
+	.byte	2                       ## DW_AT_bit_size
+	.byte	22                      ## DW_AT_data_bit_offset
+	.byte	13                      ## Abbrev [13] 0xe8:0xd DW_TAG_member
+	.long	122                     ## DW_AT_name
+	.long	260                     ## DW_AT_type
+	.byte	1                       ## DW_AT_decl_file
+	.byte	13                      ## DW_AT_decl_line
+	.byte	6                       ## DW_AT_bit_size
+	.byte	24                      ## DW_AT_data_bit_offset
+	.byte	13                      ## Abbrev [13] 0xf5:0xd DW_TAG_member
+	.long	73                      ## DW_AT_name
+	.long	260                     ## DW_AT_type
+	.byte	1                       ## DW_AT_decl_file
+	.byte	14                      ## DW_AT_decl_line
+	.byte	2                       ## DW_AT_bit_size
+	.byte	30                      ## DW_AT_data_bit_offset
+	.byte	0                       ## End Of Children Mark
+	.byte	0                       ## End Of Children Mark
+	.byte	8                       ## Abbrev [8] 0x104:0xb DW_TAG_typedef
+	.long	271                     ## DW_AT_type
+	.long	92                      ## DW_AT_name
+	.byte	2                       ## DW_AT_decl_file
+	.byte	31                      ## DW_AT_decl_line
+	.byte	7                       ## Abbrev [7] 0x10f:0x7 DW_TAG_base_type
+	.long	101                     ## DW_AT_name
+	.byte	7                       ## DW_AT_encoding
+	.byte	4                       ## DW_AT_byte_size
+	.byte	0                       ## End Of Children Mark
+Ldebug_info_end0:
+	.section	__DWARF,__debug_macinfo,regular,debug
+Ldebug_macinfo:
+	.byte	0                       ## End Of Macro List Mark
+	.section	__DWARF,__apple_names,regular,debug
+Lnames_begin:
+	.long	1212240712              ## Header Magic
+	.short	1                       ## Header Version
+	.short	0                       ## Header Hash Function
+	.long	2                       ## Header Bucket Count
+	.long	2                       ## Header Hash Count
+	.long	12                      ## Header Data Length
+	.long	0                       ## HeaderData Die Offset Base
+	.long	1                       ## HeaderData Atom Count
+	.short	1                       ## DW_ATOM_die_offset
+	.short	6                       ## DW_FORM_data4
+	.long	0                       ## Bucket 0
+	.long	1                       ## Bucket 1
+	.long	2090499946              ## Hash in Bucket 0
+	.long	177675                  ## Hash in Bucket 1
+.set Lset11, LNames0-Lnames_begin       ## Offset in Bucket 0
+	.long	Lset11
+.set Lset12, LNames1-Lnames_begin       ## Offset in Bucket 1
+	.long	Lset12
+LNames0:
+	.long	75                      ## main
+	.long	1                       ## Num DIEs
+	.long	79
+	.long	0
+LNames1:
+	.long	73                      ## f
+	.long	1                       ## Num DIEs
+	.long	42
+	.long	0
+	.section	__DWARF,__apple_objc,regular,debug
+Lobjc_begin:
+	.long	1212240712              ## Header Magic
+	.short	1                       ## Header Version
+	.short	0                       ## Header Hash Function
+	.long	1                       ## Header Bucket Count
+	.long	0                       ## Header Hash Count
+	.long	12                      ## Header Data Length
+	.long	0                       ## HeaderData Die Offset Base
+	.long	1                       ## HeaderData Atom Count
+	.short	1                       ## DW_ATOM_die_offset
+	.short	6                       ## DW_FORM_data4
+	.long	-1                      ## Bucket 0
+	.section	__DWARF,__apple_namespac,regular,debug
+Lnamespac_begin:
+	.long	1212240712              ## Header Magic
+	.short	1                       ## Header Version
+	.short	0                       ## Header Hash Function
+	.long	1                       ## Header Bucket Count
+	.long	0                       ## Header Hash Count
+	.long	12                      ## Header Data Length
+	.long	0                       ## HeaderData Die Offset Base
+	.long	1                       ## HeaderData Atom Count
+	.short	1                       ## DW_ATOM_die_offset
+	.short	6                       ## DW_FORM_data4
+	.long	-1                      ## Bucket 0
+	.section	__DWARF,__apple_types,regular,debug
+Ltypes_begin:
+	.long	1212240712              ## Header Magic
+	.short	1                       ## Header Version
+	.short	0                       ## Header Hash Function
+	.long	4                       ## Header Bucket Count
+	.long	4                       ## Header Hash Count
+	.long	20                      ## Header Data Length
+	.long	0                       ## HeaderData Die Offset Base
+	.long	3                       ## HeaderData Atom Count
+	.short	1                       ## DW_ATOM_die_offset
+	.short	6                       ## DW_FORM_data4
+	.short	3                       ## DW_ATOM_die_tag
+	.short	5                       ## DW_FORM_data2
+	.short	4                       ## DW_ATOM_type_flags
+	.short	11                      ## DW_FORM_data1
+	.long	0                       ## Bucket 0
+	.long	1                       ## Bucket 1
+	.long	3                       ## Bucket 2
+	.long	-1                      ## Bucket 3
+	.long	193495088               ## Hash in Bucket 0
+	.long	290711645               ## Hash in Bucket 1
+	.long	-1304652851             ## Hash in Bucket 1
+	.long	177658                  ## Hash in Bucket 2
+.set Lset13, Ltypes3-Ltypes_begin       ## Offset in Bucket 0
+	.long	Lset13
+.set Lset14, Ltypes1-Ltypes_begin       ## Offset in Bucket 1
+	.long	Lset14
+.set Lset15, Ltypes2-Ltypes_begin       ## Offset in Bucket 1
+	.long	Lset15
+.set Lset16, Ltypes0-Ltypes_begin       ## Offset in Bucket 2
+	.long	Lset16
+Ltypes3:
+	.long	80                      ## int
+	.long	1                       ## Num DIEs
+	.long	134
+	.short	36
+	.byte	0
+	.long	0
+Ltypes1:
+	.long	92                      ## uint32_t
+	.long	1                       ## Num DIEs
+	.long	260
+	.short	22
+	.byte	0
+	.long	0
+Ltypes2:
+	.long	101                     ## unsigned int
+	.long	1                       ## Num DIEs
+	.long	271
+	.short	36
+	.byte	0
+	.long	0
+Ltypes0:
+	.long	86                      ## U
+	.long	1                       ## Num DIEs
+	.long	141
+	.short	22
+	.byte	0
+	.long	0
+	.section	__DWARF,__debug_gnu_pubn,regular,debug
+.set Lset17, LpubNames_end0-LpubNames_begin0 ## Length of Public Names Info
+	.long	Lset17
+LpubNames_begin0:
+	.short	2                       ## DWARF Version
+.set Lset18, Lcu_begin0-Lsection_info   ## Offset of Compilation Unit Info
+	.long	Lset18
+	.long	279                     ## Compilation Unit Length
+	.long	79                      ## DIE offset
+	.byte	48                      ## Attributes: FUNCTION, EXTERNAL
+	.asciz	"main"                  ## External Name
+	.long	42                      ## DIE offset
+	.byte	48                      ## Attributes: FUNCTION, EXTERNAL
+	.asciz	"f"                     ## External Name
+	.long	0                       ## End Mark
+LpubNames_end0:
+	.section	__DWARF,__debug_gnu_pubt,regular,debug
+.set Lset19, LpubTypes_end0-LpubTypes_begin0 ## Length of Public Types Info
+	.long	Lset19
+LpubTypes_begin0:
+	.short	2                       ## DWARF Version
+.set Lset20, Lcu_begin0-Lsection_info   ## Offset of Compilation Unit Info
+	.long	Lset20
+	.long	279                     ## Compilation Unit Length
+	.long	141                     ## DIE offset
+	.byte	144                     ## Attributes: TYPE, STATIC
+	.asciz	"U"                     ## External Name
+	.long	260                     ## DIE offset
+	.byte	144                     ## Attributes: TYPE, STATIC
+	.asciz	"uint32_t"              ## External Name
+	.long	271                     ## DIE offset
+	.byte	144                     ## Attributes: TYPE, STATIC
+	.asciz	"unsigned int"          ## External Name
+	.long	134                     ## DIE offset
+	.byte	144                     ## Attributes: TYPE, STATIC
+	.asciz	"int"                   ## External Name
+	.long	0                       ## End Mark
+LpubTypes_end0:
+
+.subsections_via_symbols
+	.section	__DWARF,__debug_line,regular,debug
+Lsection_line:
+Lline_table_start0:
Index: lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/TestValueObjPassByRef.py
===================================================================
--- /dev/null
+++ lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/TestValueObjPassByRef.py
@@ -0,0 +1,27 @@
+import lldb
+from lldbsuite.test.decorators import *
+from lldbsuite.test.lldbtest import *
+from lldbsuite.test import lldbutil
+
+class TestValueObjPassByRef(TestBase):
+
+    mydir = TestBase.compute_mydir(__file__)
+
+    @skipUnlessDarwin
+    def test(self):
+        self.build()
+        self.runCmd("file " + self.getBuildArtifact("a.out"), CURRENT_EXECUTABLE_SET)
+        self.runCmd("b f");
+        self.runCmd("run");
+
+        self.expect("frame var -L", substrs = [ "rsi: (U) u = {",
+                      "scalar:   raw = 1688469761",
+                      "scalar:     a = 1",
+                      "scalar:     b = 1",
+                      "scalar:     c = 36",
+                      "scalar:     d = 2",
+                      "scalar:     e = 36",
+                      "scalar:     f = 1",
+                      "}",
+                      "}"])
+
Index: lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/Makefile
===================================================================
--- /dev/null
+++ lldb/test/API/functionalities/data-formatter/valueobj-pass-by-reg/Makefile
@@ -0,0 +1,8 @@
+EXE := a.out
+CFLAGS := -O1
+
+include Makefile.rules
+
+$(EXE):
+	$(CC) $(CFLAGS) $(SRCDIR)/main.s -c -o main.o
+	$(CC) $(CFLAGS) main.o -o a.out
Index: lldb/source/Core/ValueObjectChild.cpp
===================================================================
--- lldb/source/Core/ValueObjectChild.cpp
+++ lldb/source/Core/ValueObjectChild.cpp
@@ -199,11 +199,7 @@
           // try to extract the child value from the parent's scalar value
           {
             Scalar scalar(m_value.GetScalar());
-            if (m_bitfield_bit_size)
-              scalar.ExtractBitfield(m_bitfield_bit_size,
-                                     m_bitfield_bit_offset);
-            else
-              scalar.ExtractBitfield(8 * m_byte_size, 8 * m_byte_offset);
+            scalar.ExtractBitfield(8 * m_byte_size, 8 * m_byte_offset);
             m_value.GetScalar() = scalar;
           }
           break;
_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to