drivers/ras/amd/atl/umc.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)
Explicit cast pc to u32 to avoid sign extension while left shift
Issue reported by coverity with CID: 1593397
Signed-off-by: Karan Sanghavi <karansanghvi98@gmail.com>
---
Coverity Link:
https://scan7.scan.coverity.com/#/project-view/51975/11354?selectedIssue=1593397
---
drivers/ras/amd/atl/umc.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/ras/amd/atl/umc.c b/drivers/ras/amd/atl/umc.c
index dc8aa12f63c8..916c867faaf8 100644
--- a/drivers/ras/amd/atl/umc.c
+++ b/drivers/ras/amd/atl/umc.c
@@ -293,7 +293,7 @@ static unsigned long convert_dram_to_norm_addr_mi300(unsigned long addr)
}
/* PC bit */
- addr |= pc << bit_shifts.pc;
+ addr |= (u32)pc << bit_shifts.pc;
/* SID bits */
for (i = 0; i < NUM_SID_BITS; i++) {
---
base-commit: 81983758430957d9a5cb3333fe324fd70cf63e7e
change-id: 20241104-coverity1593397signextension-78c9b2c21d51
Best regards,
--
Karan Sanghavi <karansanghvi98@gmail.com>
On 11/4/24 11:34, Karan Sanghavi wrote: > Explicit cast pc to u32 to avoid sign extension while left shift > > Issue reported by coverity with CID: 1593397 > > Signed-off-by: Karan Sanghavi <karansanghvi98@gmail.com> > --- > Coverity Link: > https://scan7.scan.coverity.com/#/project-view/51975/11354?selectedIssue=1593397 Please include the coverity message instead of this link so reviewers without coverity accounts can see the report. > --- > drivers/ras/amd/atl/umc.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/ras/amd/atl/umc.c b/drivers/ras/amd/atl/umc.c > index dc8aa12f63c8..916c867faaf8 100644 > --- a/drivers/ras/amd/atl/umc.c > +++ b/drivers/ras/amd/atl/umc.c > @@ -293,7 +293,7 @@ static unsigned long convert_dram_to_norm_addr_mi300(unsigned long addr) > } > > /* PC bit */ > - addr |= pc << bit_shifts.pc; > + addr |= (u32)pc << bit_shifts.pc; How did you determine this is the right fix and how did test this change? > > /* SID bits */ > for (i = 0; i < NUM_SID_BITS; i++) { > > --- > base-commit: 81983758430957d9a5cb3333fe324fd70cf63e7e > change-id: 20241104-coverity1593397signextension-78c9b2c21d51 > > Best regards, thanks, -- Shuah
On Mon, Nov 04, 2024 at 02:51:56PM -0700, Shuah Khan wrote: > On 11/4/24 11:34, Karan Sanghavi wrote: > > Explicit cast pc to u32 to avoid sign extension while left shift > > > > Issue reported by coverity with CID: 1593397 > > > > Signed-off-by: Karan Sanghavi <karansanghvi98@gmail.com> > > --- > > Coverity Link: > > https://scan7.scan.coverity.com/#/project-view/51975/11354?selectedIssue=1593397 > > Please include the coverity message instead of this link so > reviewers without coverity accounts can see the report. > sure will keep it in mind. > > --- > > drivers/ras/amd/atl/umc.c | 2 +- > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > diff --git a/drivers/ras/amd/atl/umc.c b/drivers/ras/amd/atl/umc.c > > index dc8aa12f63c8..916c867faaf8 100644 > > --- a/drivers/ras/amd/atl/umc.c > > +++ b/drivers/ras/amd/atl/umc.c > > @@ -293,7 +293,7 @@ static unsigned long convert_dram_to_norm_addr_mi300(unsigned long addr) > > } > > /* PC bit */ > > - addr |= pc << bit_shifts.pc; > > + addr |= (u32)pc << bit_shifts.pc; > > How did you determine this is the right fix and how did > test this change? > #define ADDR_SEL_2_CHAN GENMASK(15, 12) bit_shifts.pc = 5 + FIELD_GET(ADDR_SEL_2_CHAN, temp); After reviewing the code, I found that bit_shifts.pc can reach a maximum value of 20. Left-shifting a u16 pc by this amount results in an implicit promotion to an int64_t, which can cause sign extension and lead to unintended negative values. To avoid this, casting to a larger data type (such as u64) woulbe be most appropriate solution here. Also,using u64 would be more appropriate rather than u32. Should I send a new patch with u64? > > /* SID bits */ > > for (i = 0; i < NUM_SID_BITS; i++) { > > > > --- > > base-commit: 81983758430957d9a5cb3333fe324fd70cf63e7e > > change-id: 20241104-coverity1593397signextension-78c9b2c21d51 > > > > Best regards, > > thanks, > -- Shuah Thank you, Karan.
On Tue, Nov 05, 2024 at 04:20:27PM +0000, Karan Sanghavi wrote: > On Mon, Nov 04, 2024 at 02:51:56PM -0700, Shuah Khan wrote: > > On 11/4/24 11:34, Karan Sanghavi wrote: > > > Explicit cast pc to u32 to avoid sign extension while left shift > > > > > > Issue reported by coverity with CID: 1593397 > > > > > > Signed-off-by: Karan Sanghavi <karansanghvi98@gmail.com> > > > --- > > > Coverity Link: > > > https://scan7.scan.coverity.com/#/project-view/51975/11354?selectedIssue=1593397 > > > > Please include the coverity message instead of this link so > > reviewers without coverity accounts can see the report. > > > sure will keep it in mind. Please do share this as it'll help provide context. > > > --- > > > drivers/ras/amd/atl/umc.c | 2 +- > > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > > > diff --git a/drivers/ras/amd/atl/umc.c b/drivers/ras/amd/atl/umc.c > > > index dc8aa12f63c8..916c867faaf8 100644 > > > --- a/drivers/ras/amd/atl/umc.c > > > +++ b/drivers/ras/amd/atl/umc.c > > > @@ -293,7 +293,7 @@ static unsigned long convert_dram_to_norm_addr_mi300(unsigned long addr) > > > } > > > /* PC bit */ > > > - addr |= pc << bit_shifts.pc; > > > + addr |= (u32)pc << bit_shifts.pc; > > > > How did you determine this is the right fix and how did > > test this change? > > > #define ADDR_SEL_2_CHAN GENMASK(15, 12) > > bit_shifts.pc = 5 + FIELD_GET(ADDR_SEL_2_CHAN, temp); > > After reviewing the code, I found that bit_shifts.pc can reach a maximum value of 20. > Left-shifting a u16 pc by this amount results in an implicit promotion to an int64_t, > which can cause sign extension and lead to unintended negative values. > The 'pc' variable holds a single bit in practice. #define MI300_UMC_MCA_PC BIT(25) pc = FIELD_GET(MI300_UMC_MCA_PC, addr); > To avoid this, casting to a larger data type (such as u64) woulbe be most > appropriate solution here. > > Also,using u64 would be more appropriate rather than u32. > > Should I send a new patch with u64? > Another option is to follow the style in the rest of the function and use the 'temp' variable. /* PC bit */ - addr |= pc << bit_shifts.pc; + temp = pc; + addr |= temp << bit_shifts.pc; Or we can change the variable declarations to all be 'unsigned long' to match input/return value. Thanks, Yazen
© 2016 - 2024 Red Hat, Inc.