public inbox for gdb-patches@sourceware.org
 help / color / mirror / Atom feed
* Re:[PATCH] gdb/csky complete csky_dwarf_reg_to_regnum
@ 2022-07-18  2:50 李江帅
  2022-07-18 16:16 ` Tom Tromey
  0 siblings, 1 reply; 2+ messages in thread
From: 李江帅 @ 2022-07-18  2:50 UTC (permalink / raw)
  To: Tom Tromey; +Cc: gdb-patches

>>>>>> Jiangshuai Li <jiangshuai_li@c-sky.com> writes:

>
>> +  if (dw_reg >= CSKY_R0_REGNUM && dw_reg <= (CSKY_R0_REGNUM + 31))
>
>This line and some others have too many parentheses.

This line meens that "if (dw_reg >=0 && dw_reg <= 31)". As i does not define CSKY_R31_REGNUM,
i wrote 31 as (CSKY_R0_REGNUM + 31).

>> +  /* For Float and Vector pseudo registers.  */
>> +  if ((dw_reg >= FV_PSEUDO_REGNO_FIRST)  && (dw_reg <= FV_PSEUDO_REGNO_LAST))
>> +    {
>> +      char name_buf[4];
>> +
>> +      xsnprintf (name_buf, sizeof (name_buf), "s%d",
>> +                 dw_reg - FV_PSEUDO_REGNO_FIRST);
>> +      return user_reg_map_name_to_regnum (gdbarch, name_buf,
>> +                                          strlen (name_buf));
>
>This seems like a very roundabout approach.  Is there a reason it's done
>this way?

I am not sure what you mean, this code mean that:
if (dw_reg >= 74 && dw_reg <= 201),  dw_reg will corresponds to a pseudo register
added for float or vector registers.

Similar code: arm-tdep.c: 4876

>
>Tom

Jiangshuai.

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2022-07-18 16:17 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-07-18  2:50 Re:[PATCH] gdb/csky complete csky_dwarf_reg_to_regnum 李江帅
2022-07-18 16:16 ` Tom Tromey

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).