* sb_edac 32-bit compile fail due to 64-bit divide @ 2011-11-03 14:07 Josh Boyer 2011-11-03 14:32 ` Mauro Carvalho Chehab 2011-11-07 21:29 ` [PATCH] Fix sb_edac compilation with 32 bits kernels Mauro Carvalho Chehab 0 siblings, 2 replies; 11+ messages in thread From: Josh Boyer @ 2011-11-03 14:07 UTC (permalink / raw) To: Mauro Carvalho Chehab; +Cc: linux-edac, linux-kernel Hi, It seems the newly added EDAC driver for SandyBridge won't build on 32-bit x86 because of a 64-bit divide somewhere: drivers/edac/sb_edac.c: In function 'get_memory_error_data': drivers/edac/sb_edac.c:861:2: warning: left shift count >= width of type [enabled by default] <snip> ERROR: "__udivdi3" [drivers/edac/sb_edac.ko] undefined! make[1]: *** [__modpost] Error 1 make: *** [modules] Error 2 You can find the full build log here: http://koji.fedoraproject.org/koji/getfile?taskID=3482579&name=build.log Before I go digging into where this is done and what to do about it, I do want to confirm that it is supposed to work on a 32-bit kernel, correct? josh ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: sb_edac 32-bit compile fail due to 64-bit divide 2011-11-03 14:07 sb_edac 32-bit compile fail due to 64-bit divide Josh Boyer @ 2011-11-03 14:32 ` Mauro Carvalho Chehab 2011-11-03 14:43 ` Josh Boyer 2011-11-07 21:29 ` [PATCH] Fix sb_edac compilation with 32 bits kernels Mauro Carvalho Chehab 1 sibling, 1 reply; 11+ messages in thread From: Mauro Carvalho Chehab @ 2011-11-03 14:32 UTC (permalink / raw) To: Josh Boyer; +Cc: linux-edac, linux-kernel Em 03-11-2011 12:07, Josh Boyer escreveu: > Hi, > > It seems the newly added EDAC driver for SandyBridge won't build on > 32-bit x86 because of a 64-bit divide somewhere: > > drivers/edac/sb_edac.c: In function 'get_memory_error_data': > drivers/edac/sb_edac.c:861:2: warning: left shift count >= width of type > [enabled by default] > <snip> > ERROR: "__udivdi3" [drivers/edac/sb_edac.ko] undefined! > make[1]: *** [__modpost] Error 1 > make: *** [modules] Error 2 > > You can find the full build log here: > > http://koji.fedoraproject.org/koji/getfile?taskID=3482579&name=build.log > > Before I go digging into where this is done and what to do about it, I > do want to confirm that it is supposed to work on a 32-bit kernel, > correct? Thanks for pointing it! Well, I didn't test it on a 32-bit kernel. It should work through. It is probably due to those debug lines: debugf0("CH#%d RIR#%d INTL#%d, offset %Lu.%03Lu GB (0x%016Lx), tgt: %d, reg=0x%08x\n", i, j, k, tmp_mb / 1000, tmp_mb % 1000, ((u64)tmp_mb) << 20L, (u32)RIR_RNK_TGT(reg), reg); (same kind of calculus is recurrent at the driver) Maybe the easiest way would be to write a function that would call do_div() internally, and output a string with something similar to: sprintf(msg, "%Lu.%03Lu GB", tmp_mb / 1000, tmp_mb % 1000); Of course, an interim fix would be to make it depend on CONFIG_64BIT or CONFIG_X86_64. Regards, Mauro ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: sb_edac 32-bit compile fail due to 64-bit divide 2011-11-03 14:32 ` Mauro Carvalho Chehab @ 2011-11-03 14:43 ` Josh Boyer 2011-11-03 16:31 ` Luck, Tony 2011-11-03 17:20 ` Mauro Carvalho Chehab 0 siblings, 2 replies; 11+ messages in thread From: Josh Boyer @ 2011-11-03 14:43 UTC (permalink / raw) To: Mauro Carvalho Chehab; +Cc: linux-edac, linux-kernel On Thu, Nov 03, 2011 at 12:32:31PM -0200, Mauro Carvalho Chehab wrote: > Em 03-11-2011 12:07, Josh Boyer escreveu: > > Hi, > > > > It seems the newly added EDAC driver for SandyBridge won't build on > > 32-bit x86 because of a 64-bit divide somewhere: > > > > drivers/edac/sb_edac.c: In function 'get_memory_error_data': > > drivers/edac/sb_edac.c:861:2: warning: left shift count >= width of type > > [enabled by default] > > <snip> > > ERROR: "__udivdi3" [drivers/edac/sb_edac.ko] undefined! > > make[1]: *** [__modpost] Error 1 > > make: *** [modules] Error 2 > > > > You can find the full build log here: > > > > http://koji.fedoraproject.org/koji/getfile?taskID=3482579&name=build.log > > > > Before I go digging into where this is done and what to do about it, I > > do want to confirm that it is supposed to work on a 32-bit kernel, > > correct? > > Thanks for pointing it! > > Well, I didn't test it on a 32-bit kernel. It should work through. > > It is probably due to those debug lines: > debugf0("CH#%d RIR#%d INTL#%d, offset %Lu.%03Lu GB (0x%016Lx), tgt: %d, reg=0x%08x\n", > i, j, k, > tmp_mb / 1000, tmp_mb % 1000, > ((u64)tmp_mb) << 20L, > (u32)RIR_RNK_TGT(reg), > reg); > (same kind of calculus is recurrent at the driver) All of that should basically not exist in this build because the debugf* macros depend on CONFIG_EDAC_DEBUG, which isn't set in this build. The problem seems to be somewhere else. I would guess line 1056: addr /= sck_xch; addr is a u64. > Maybe the easiest way would be to write a function that would call do_div() internally, > and output a string with something similar to: > > sprintf(msg, "%Lu.%03Lu GB", tmp_mb / 1000, tmp_mb % 1000); > > Of course, an interim fix would be to make it depend on CONFIG_64BIT or CONFIG_X86_64. That would work I guess. It's up to you. > > Regards, > Mauro ^ permalink raw reply [flat|nested] 11+ messages in thread
* RE: sb_edac 32-bit compile fail due to 64-bit divide 2011-11-03 14:43 ` Josh Boyer @ 2011-11-03 16:31 ` Luck, Tony 2011-11-03 17:41 ` Mauro Carvalho Chehab 2011-11-03 17:20 ` Mauro Carvalho Chehab 1 sibling, 1 reply; 11+ messages in thread From: Luck, Tony @ 2011-11-03 16:31 UTC (permalink / raw) To: Josh Boyer, Mauro Carvalho Chehab Cc: linux-edac@vger.kernel.org, linux-kernel@vger.kernel.org >> Of course, an interim fix would be to make it depend on CONFIG_64BIT or CONFIG_X86_64. > > That would work I guess. It's up to you. Typically the test platforms I get have pretty much the minimum sane memory configuration - my Sandy Bridge EP machine came with 32GB of memory (which is theoretically bootable with a 32-bit kernel, but really isn't going to be much fun to use). So I would think that time could be spent on more productive things than making this edac driver work on 32-bit. My vote is for the "depends on 64-bit" solution. -Tony ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: sb_edac 32-bit compile fail due to 64-bit divide 2011-11-03 16:31 ` Luck, Tony @ 2011-11-03 17:41 ` Mauro Carvalho Chehab 2011-11-03 17:48 ` Josh Boyer 0 siblings, 1 reply; 11+ messages in thread From: Mauro Carvalho Chehab @ 2011-11-03 17:41 UTC (permalink / raw) To: Luck, Tony Cc: Josh Boyer, linux-edac@vger.kernel.org, linux-kernel@vger.kernel.org Em 03-11-2011 14:31, Luck, Tony escreveu: >>> Of course, an interim fix would be to make it depend on CONFIG_64BIT or CONFIG_X86_64. >> >> That would work I guess. It's up to you. > > Typically the test platforms I get have pretty much the minimum sane memory > configuration - my Sandy Bridge EP machine came with 32GB of memory (which > is theoretically bootable with a 32-bit kernel, but really isn't going to > be much fun to use). So I would think that time could be spent on more > productive things than making this edac driver work on 32-bit. My vote > is for the "depends on 64-bit" solution. Works for me. It would be a trivial patch. We can later fix it for 32 bits, if someone has any usage for it with 32 bits kernels. Thanks, Mauro. ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: sb_edac 32-bit compile fail due to 64-bit divide 2011-11-03 17:41 ` Mauro Carvalho Chehab @ 2011-11-03 17:48 ` Josh Boyer 2011-11-03 17:51 ` Mauro Carvalho Chehab 0 siblings, 1 reply; 11+ messages in thread From: Josh Boyer @ 2011-11-03 17:48 UTC (permalink / raw) To: Mauro Carvalho Chehab Cc: Luck, Tony, linux-edac@vger.kernel.org, linux-kernel@vger.kernel.org On Thu, Nov 03, 2011 at 03:41:52PM -0200, Mauro Carvalho Chehab wrote: > Em 03-11-2011 14:31, Luck, Tony escreveu: > >>> Of course, an interim fix would be to make it depend on CONFIG_64BIT or CONFIG_X86_64. > >> > >> That would work I guess. It's up to you. > > > > Typically the test platforms I get have pretty much the minimum sane memory > > configuration - my Sandy Bridge EP machine came with 32GB of memory (which > > is theoretically bootable with a 32-bit kernel, but really isn't going to > > be much fun to use). So I would think that time could be spent on more > > productive things than making this edac driver work on 32-bit. My vote > > is for the "depends on 64-bit" solution. > > Works for me. It would be a trivial patch. We can later fix it for 32 bits, if > someone has any usage for it with 32 bits kernels. How's the below? josh --- From: Josh Boyer <jwboyer@redhat.com> Subject: [PATCH] edac: Only build sb_edac on 64-bit The sb_edac driver is marginally useful on a 32-bit kernel, and currently has 64-bit divide compile errors when building that config. For now, make this build on only for 64-bit kernels. Signed-off-by: Josh Boyer <jwboyer@redhat.com> --- diff --git a/drivers/edac/Kconfig b/drivers/edac/Kconfig index 203361e..5948a21 100644 --- a/drivers/edac/Kconfig +++ b/drivers/edac/Kconfig @@ -214,7 +214,7 @@ config EDAC_I7300 config EDAC_SBRIDGE tristate "Intel Sandy-Bridge Integrated MC" - depends on EDAC_MM_EDAC && PCI && X86 && X86_MCE_INTEL + depends on EDAC_MM_EDAC && PCI && X86_64 && X86_MCE_INTEL depends on EXPERIMENTAL help Support for error detection and correction the Intel ^ permalink raw reply related [flat|nested] 11+ messages in thread
* Re: sb_edac 32-bit compile fail due to 64-bit divide 2011-11-03 17:48 ` Josh Boyer @ 2011-11-03 17:51 ` Mauro Carvalho Chehab 0 siblings, 0 replies; 11+ messages in thread From: Mauro Carvalho Chehab @ 2011-11-03 17:51 UTC (permalink / raw) To: Josh Boyer Cc: Luck, Tony, linux-edac@vger.kernel.org, linux-kernel@vger.kernel.org Em 03-11-2011 15:48, Josh Boyer escreveu: > How's the below? Ack. I'll add it on my tree and submit it to Linus for its addition. > > josh > > --- > > From: Josh Boyer <jwboyer@redhat.com> > Subject: [PATCH] edac: Only build sb_edac on 64-bit > > The sb_edac driver is marginally useful on a 32-bit kernel, and > currently has 64-bit divide compile errors when building that config. > For now, make this build on only for 64-bit kernels. > > Signed-off-by: Josh Boyer <jwboyer@redhat.com> > > --- > > diff --git a/drivers/edac/Kconfig b/drivers/edac/Kconfig > index 203361e..5948a21 100644 > --- a/drivers/edac/Kconfig > +++ b/drivers/edac/Kconfig > @@ -214,7 +214,7 @@ config EDAC_I7300 > > config EDAC_SBRIDGE > tristate "Intel Sandy-Bridge Integrated MC" > - depends on EDAC_MM_EDAC && PCI && X86 && X86_MCE_INTEL > + depends on EDAC_MM_EDAC && PCI && X86_64 && X86_MCE_INTEL > depends on EXPERIMENTAL > help > Support for error detection and correction the Intel > -- > To unsubscribe from this list: send the line "unsubscribe linux-edac" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: sb_edac 32-bit compile fail due to 64-bit divide 2011-11-03 14:43 ` Josh Boyer 2011-11-03 16:31 ` Luck, Tony @ 2011-11-03 17:20 ` Mauro Carvalho Chehab 1 sibling, 0 replies; 11+ messages in thread From: Mauro Carvalho Chehab @ 2011-11-03 17:20 UTC (permalink / raw) To: Josh Boyer; +Cc: linux-edac, linux-kernel Em 03-11-2011 12:43, Josh Boyer escreveu: > On Thu, Nov 03, 2011 at 12:32:31PM -0200, Mauro Carvalho Chehab wrote: >> Em 03-11-2011 12:07, Josh Boyer escreveu: >>> Hi, >>> >>> It seems the newly added EDAC driver for SandyBridge won't build on >>> 32-bit x86 because of a 64-bit divide somewhere: >>> >>> drivers/edac/sb_edac.c: In function 'get_memory_error_data': >>> drivers/edac/sb_edac.c:861:2: warning: left shift count >= width of type >>> [enabled by default] >>> <snip> >>> ERROR: "__udivdi3" [drivers/edac/sb_edac.ko] undefined! >>> make[1]: *** [__modpost] Error 1 >>> make: *** [modules] Error 2 >>> >>> You can find the full build log here: >>> >>> http://koji.fedoraproject.org/koji/getfile?taskID=3482579&name=build.log >>> >>> Before I go digging into where this is done and what to do about it, I >>> do want to confirm that it is supposed to work on a 32-bit kernel, >>> correct? >> >> Thanks for pointing it! >> >> Well, I didn't test it on a 32-bit kernel. It should work through. >> >> It is probably due to those debug lines: >> debugf0("CH#%d RIR#%d INTL#%d, offset %Lu.%03Lu GB (0x%016Lx), tgt: %d, reg=0x%08x\n", >> i, j, k, >> tmp_mb / 1000, tmp_mb % 1000, >> ((u64)tmp_mb) << 20L, >> (u32)RIR_RNK_TGT(reg), >> reg); >> (same kind of calculus is recurrent at the driver) > > All of that should basically not exist in this build because the debugf* > macros depend on CONFIG_EDAC_DEBUG, which isn't set in this build. The > problem seems to be somewhere else. I strongly recommend you to enable EDAC_DEBUG if you're building this driver. This driver is experimental, and it may be blaming the wrong memory DIMMs, as Sandy Bridge bios allows setting a large myriad of configurations. Among them, only one were actually tested. > > I would guess line 1056: > > addr /= sck_xch; > > addr is a u64. Ok. Well, a patch fixing it should be done with debug enabled, to get all cases. >> Maybe the easiest way would be to write a function that would call do_div() internally, >> and output a string with something similar to: >> >> sprintf(msg, "%Lu.%03Lu GB", tmp_mb / 1000, tmp_mb % 1000); >> >> Of course, an interim fix would be to make it depend on CONFIG_64BIT or CONFIG_X86_64. > > That would work I guess. It's up to you. I prefer a patch fixing the issue. Not sure if I'll have time to work in it today, as I'm stuck with the second part of media patches for 3.2. >> >> Regards, >> Mauro > -- > To unsubscribe from this list: send the line "unsubscribe linux-edac" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH] Fix sb_edac compilation with 32 bits kernels 2011-11-03 14:07 sb_edac 32-bit compile fail due to 64-bit divide Josh Boyer 2011-11-03 14:32 ` Mauro Carvalho Chehab @ 2011-11-07 21:29 ` Mauro Carvalho Chehab 2011-11-07 21:37 ` Josh Boyer 1 sibling, 1 reply; 11+ messages in thread From: Mauro Carvalho Chehab @ 2011-11-07 21:29 UTC (permalink / raw) To: Josh Boyer; +Cc: linux-edac, linux-kernel Em 03-11-2011 12:07, Josh Boyer escreveu: > Hi, > > It seems the newly added EDAC driver for SandyBridge won't build on > 32-bit x86 because of a 64-bit divide somewhere: > > drivers/edac/sb_edac.c: In function 'get_memory_error_data': > drivers/edac/sb_edac.c:861:2: warning: left shift count >= width of type > [enabled by default] > <snip> > ERROR: "__udivdi3" [drivers/edac/sb_edac.ko] undefined! > make[1]: *** [__modpost] Error 1 > make: *** [modules] Error 2 > > You can find the full build log here: > > http://koji.fedoraproject.org/koji/getfile?taskID=3482579&name=build.log > > Before I go digging into where this is done and what to do about it, I > do want to confirm that it is supposed to work on a 32-bit kernel, > correct? Ok, I found some spare time to work on a patch for fixing it. As Tony pointed, it probably doesn't make much sense on running this driver with 32 bits, nor I tested the patch, but, in any case, the fix is trivial. Regards, Mauro - From: Mauro Carvalho Chehab <mchehab@redhat.com> Date: Mon, 7 Nov 2011 19:26:53 -0200 As reported by Josh Boyer <jwboyer@redhat.com>: > drivers/edac/sb_edac.c: In function 'get_memory_error_data': > drivers/edac/sb_edac.c:861:2: warning: left shift count >= width of type > [enabled by default] > <snip> > ERROR: "__udivdi3" [drivers/edac/sb_edac.ko] undefined! > make[1]: *** [__modpost] Error 1 > make: *** [modules] Error 2 PS.: compile-tested only Reported-by: Josh Boyer <jwboyer@redhat.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com> diff --git a/drivers/edac/Kconfig b/drivers/edac/Kconfig index 5948a21..203361e 100644 --- a/drivers/edac/Kconfig +++ b/drivers/edac/Kconfig @@ -214,7 +214,7 @@ config EDAC_I7300 config EDAC_SBRIDGE tristate "Intel Sandy-Bridge Integrated MC" - depends on EDAC_MM_EDAC && PCI && X86_64 && X86_MCE_INTEL + depends on EDAC_MM_EDAC && PCI && X86 && X86_MCE_INTEL depends on EXPERIMENTAL help Support for error detection and correction the Intel diff --git a/drivers/edac/sb_edac.c b/drivers/edac/sb_edac.c index 7a402bf..10927ff 100644 --- a/drivers/edac/sb_edac.c +++ b/drivers/edac/sb_edac.c @@ -20,6 +20,7 @@ #include <linux/mmzone.h> #include <linux/smp.h> #include <linux/bitmap.h> +#include <linux/math64.h> #include <asm/processor.h> #include <asm/mce.h> @@ -670,6 +671,7 @@ static void get_memory_layout(const struct mem_ctl_info *mci) u32 reg; u64 limit, prv = 0; u64 tmp_mb; + u32 mb, kb; u32 rir_way; /* @@ -682,8 +684,9 @@ static void get_memory_layout(const struct mem_ctl_info *mci) pvt->tolm = GET_TOLM(reg); tmp_mb = (1 + pvt->tolm) >> 20; - debugf0("TOLM: %Lu.%03Lu GB (0x%016Lx)\n", - tmp_mb / 1000, tmp_mb % 1000, (u64)pvt->tolm); + mb = div_u64_rem(tmp_mb, 1000, &kb); + debugf0("TOLM: %u.%03u GB (0x%016Lx)\n", + mb, kb, (u64)pvt->tolm); /* Address range is already 45:25 */ pci_read_config_dword(pvt->pci_sad1, TOHM, @@ -691,8 +694,9 @@ static void get_memory_layout(const struct mem_ctl_info *mci) pvt->tohm = GET_TOHM(reg); tmp_mb = (1 + pvt->tohm) >> 20; - debugf0("TOHM: %Lu.%03Lu GB (0x%016Lx)", - tmp_mb / 1000, tmp_mb % 1000, (u64)pvt->tohm); + mb = div_u64_rem(tmp_mb, 1000, &kb); + debugf0("TOHM: %u.%03u GB (0x%016Lx)", + mb, kb, (u64)pvt->tohm); /* * Step 2) Get SAD range and SAD Interleave list @@ -714,10 +718,11 @@ static void get_memory_layout(const struct mem_ctl_info *mci) break; tmp_mb = (limit + 1) >> 20; - debugf0("SAD#%d %s up to %Lu.%03Lu GB (0x%016Lx) %s reg=0x%08x\n", + mb = div_u64_rem(tmp_mb, 1000, &kb); + debugf0("SAD#%d %s up to %u.%03u GB (0x%016Lx) %s reg=0x%08x\n", n_sads, get_dram_attr(reg), - tmp_mb / 1000, tmp_mb % 1000, + mb, kb, ((u64)tmp_mb) << 20L, INTERLEAVE_MODE(reg) ? "Interleave: 8:6" : "Interleave: [8:6]XOR[18:16]", reg); @@ -747,8 +752,9 @@ static void get_memory_layout(const struct mem_ctl_info *mci) break; tmp_mb = (limit + 1) >> 20; - debugf0("TAD#%d: up to %Lu.%03Lu GB (0x%016Lx), socket interleave %d, memory interleave %d, TGT: %d, %d, %d, %d, reg=0x%08x\n", - n_tads, tmp_mb / 1000, tmp_mb % 1000, + mb = div_u64_rem(tmp_mb, 1000, &kb); + debugf0("TAD#%d: up to %u.%03u GB (0x%016Lx), socket interleave %d, memory interleave %d, TGT: %d, %d, %d, %d, reg=0x%08x\n", + n_tads, mb, kb, ((u64)tmp_mb) << 20L, (u32)TAD_SOCK(reg), (u32)TAD_CH(reg), @@ -771,9 +777,10 @@ static void get_memory_layout(const struct mem_ctl_info *mci) tad_ch_nilv_offset[j], ®); tmp_mb = TAD_OFFSET(reg) >> 20; - debugf0("TAD CH#%d, offset #%d: %Lu.%03Lu GB (0x%016Lx), reg=0x%08x\n", + mb = div_u64_rem(tmp_mb, 1000, &kb); + debugf0("TAD CH#%d, offset #%d: %u.%03u GB (0x%016Lx), reg=0x%08x\n", i, j, - tmp_mb / 1000, tmp_mb % 1000, + mb, kb, ((u64)tmp_mb) << 20L, reg); } @@ -795,9 +802,10 @@ static void get_memory_layout(const struct mem_ctl_info *mci) tmp_mb = RIR_LIMIT(reg) >> 20; rir_way = 1 << RIR_WAY(reg); - debugf0("CH#%d RIR#%d, limit: %Lu.%03Lu GB (0x%016Lx), way: %d, reg=0x%08x\n", + mb = div_u64_rem(tmp_mb, 1000, &kb); + debugf0("CH#%d RIR#%d, limit: %u.%03u GB (0x%016Lx), way: %d, reg=0x%08x\n", i, j, - tmp_mb / 1000, tmp_mb % 1000, + mb, kb, ((u64)tmp_mb) << 20L, rir_way, reg); @@ -808,9 +816,10 @@ static void get_memory_layout(const struct mem_ctl_info *mci) ®); tmp_mb = RIR_OFFSET(reg) << 6; - debugf0("CH#%d RIR#%d INTL#%d, offset %Lu.%03Lu GB (0x%016Lx), tgt: %d, reg=0x%08x\n", + mb = div_u64_rem(tmp_mb, 1000, &kb); + debugf0("CH#%d RIR#%d INTL#%d, offset %u.%03u GB (0x%016Lx), tgt: %d, reg=0x%08x\n", i, j, k, - tmp_mb / 1000, tmp_mb % 1000, + mb, kb, ((u64)tmp_mb) << 20L, (u32)RIR_RNK_TGT(reg), reg); @@ -848,6 +857,7 @@ static int get_memory_error_data(struct mem_ctl_info *mci, u8 ch_way,sck_way; u32 tad_offset; u32 rir_way; + u32 mb, kb; u64 ch_addr, offset, limit, prv = 0; @@ -858,7 +868,7 @@ static int get_memory_error_data(struct mem_ctl_info *mci, * range (e. g. VGA addresses). It is unlikely, however, that the * memory controller would generate an error on that range. */ - if ((addr > (u64) pvt->tolm) && (addr < (1L << 32))) { + if ((addr > (u64) pvt->tolm) && (addr < (1LL << 32))) { sprintf(msg, "Error at TOLM area, on addr 0x%08Lx", addr); edac_mc_handle_ce_no_info(mci, msg); return -EINVAL; @@ -1053,7 +1063,7 @@ static int get_memory_error_data(struct mem_ctl_info *mci, ch_addr = addr & 0x7f; /* Remove socket wayness and remove 6 bits */ addr >>= 6; - addr /= sck_xch; + addr = div_u64(addr, sck_xch); #if 0 /* Divide by channel way */ addr = addr / ch_way; @@ -1073,10 +1083,10 @@ static int get_memory_error_data(struct mem_ctl_info *mci, continue; limit = RIR_LIMIT(reg); - - debugf0("RIR#%d, limit: %Lu.%03Lu GB (0x%016Lx), way: %d\n", + mb = div_u64_rem(limit >> 20, 1000, &kb); + debugf0("RIR#%d, limit: %u.%03u GB (0x%016Lx), way: %d\n", n_rir, - (limit >> 20) / 1000, (limit >> 20) % 1000, + mb, kb, limit, 1 << RIR_WAY(reg)); if (ch_addr <= limit) ^ permalink raw reply related [flat|nested] 11+ messages in thread
* Re: [PATCH] Fix sb_edac compilation with 32 bits kernels 2011-11-07 21:29 ` [PATCH] Fix sb_edac compilation with 32 bits kernels Mauro Carvalho Chehab @ 2011-11-07 21:37 ` Josh Boyer 2011-11-07 21:54 ` Mauro Carvalho Chehab 0 siblings, 1 reply; 11+ messages in thread From: Josh Boyer @ 2011-11-07 21:37 UTC (permalink / raw) To: Mauro Carvalho Chehab; +Cc: linux-edac, linux-kernel On Mon, Nov 07, 2011 at 07:29:45PM -0200, Mauro Carvalho Chehab wrote: > @@ -670,6 +671,7 @@ static void get_memory_layout(const struct mem_ctl_info *mci) > u32 reg; > u64 limit, prv = 0; > u64 tmp_mb; > + u32 mb, kb; > u32 rir_way; > > /* > @@ -682,8 +684,9 @@ static void get_memory_layout(const struct mem_ctl_info *mci) > pvt->tolm = GET_TOLM(reg); > tmp_mb = (1 + pvt->tolm) >> 20; > > - debugf0("TOLM: %Lu.%03Lu GB (0x%016Lx)\n", > - tmp_mb / 1000, tmp_mb % 1000, (u64)pvt->tolm); > + mb = div_u64_rem(tmp_mb, 1000, &kb); > + debugf0("TOLM: %u.%03u GB (0x%016Lx)\n", > + mb, kb, (u64)pvt->tolm); So I realize you said that EDAC_DEBUG should (for now) always be enabled when this driver is built, but you just added a bunch of 64-bit divides outside of the debugfX stuff. Doesn't that mean you'll be doing those divides in the non-debug case as well, and then most likely getting an unused varible warning when you turn EDAC_DEBUG off? > @@ -858,7 +868,7 @@ static int get_memory_error_data(struct mem_ctl_info *mci, > * range (e. g. VGA addresses). It is unlikely, however, that the > * memory controller would generate an error on that range. > */ > - if ((addr > (u64) pvt->tolm) && (addr < (1L << 32))) { > + if ((addr > (u64) pvt->tolm) && (addr < (1LL << 32))) { > sprintf(msg, "Error at TOLM area, on addr 0x%08Lx", addr); > edac_mc_handle_ce_no_info(mci, msg); > return -EINVAL; > @@ -1053,7 +1063,7 @@ static int get_memory_error_data(struct mem_ctl_info *mci, > ch_addr = addr & 0x7f; > /* Remove socket wayness and remove 6 bits */ > addr >>= 6; > - addr /= sck_xch; > + addr = div_u64(addr, sck_xch); > #if 0 > /* Divide by channel way */ > addr = addr / ch_way; Those two parts look ok. josh ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH] Fix sb_edac compilation with 32 bits kernels 2011-11-07 21:37 ` Josh Boyer @ 2011-11-07 21:54 ` Mauro Carvalho Chehab 0 siblings, 0 replies; 11+ messages in thread From: Mauro Carvalho Chehab @ 2011-11-07 21:54 UTC (permalink / raw) To: Josh Boyer; +Cc: linux-edac, linux-kernel Em 07-11-2011 19:37, Josh Boyer escreveu: > On Mon, Nov 07, 2011 at 07:29:45PM -0200, Mauro Carvalho Chehab wrote: >> @@ -670,6 +671,7 @@ static void get_memory_layout(const struct mem_ctl_info *mci) >> u32 reg; >> u64 limit, prv = 0; >> u64 tmp_mb; >> + u32 mb, kb; >> u32 rir_way; >> >> /* >> @@ -682,8 +684,9 @@ static void get_memory_layout(const struct mem_ctl_info *mci) >> pvt->tolm = GET_TOLM(reg); >> tmp_mb = (1 + pvt->tolm) >> 20; >> >> - debugf0("TOLM: %Lu.%03Lu GB (0x%016Lx)\n", >> - tmp_mb / 1000, tmp_mb % 1000, (u64)pvt->tolm); >> + mb = div_u64_rem(tmp_mb, 1000, &kb); >> + debugf0("TOLM: %u.%03u GB (0x%016Lx)\n", >> + mb, kb, (u64)pvt->tolm); > > So I realize you said that EDAC_DEBUG should (for now) always be enabled > when this driver is built, but you just added a bunch of 64-bit divides > outside of the debugfX stuff. Doesn't that mean you'll be doing those > divides in the non-debug case as well, and then most likely getting an > unused varible warning when you turn EDAC_DEBUG off? You're right. Some additional logic is needed to remove the warnings and unneeded calculus when debug is disabled. I may eventually work on it when I have time. In any case, we gave a fix already for kernel 3.2, and this patch is an alternative for those brave enough to test this driver with a 32 bits PAE kernel. > >> @@ -858,7 +868,7 @@ static int get_memory_error_data(struct mem_ctl_info *mci, >> * range (e. g. VGA addresses). It is unlikely, however, that the >> * memory controller would generate an error on that range. >> */ >> - if ((addr > (u64) pvt->tolm) && (addr < (1L << 32))) { >> + if ((addr > (u64) pvt->tolm) && (addr < (1LL << 32))) { >> sprintf(msg, "Error at TOLM area, on addr 0x%08Lx", addr); >> edac_mc_handle_ce_no_info(mci, msg); >> return -EINVAL; >> @@ -1053,7 +1063,7 @@ static int get_memory_error_data(struct mem_ctl_info *mci, >> ch_addr = addr & 0x7f; >> /* Remove socket wayness and remove 6 bits */ >> addr >>= 6; >> - addr /= sck_xch; >> + addr = div_u64(addr, sck_xch); >> #if 0 >> /* Divide by channel way */ >> addr = addr / ch_way; > > Those two parts look ok. > > josh > -- > To unsubscribe from this list: send the line "unsubscribe linux-edac" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 11+ messages in thread
end of thread, other threads:[~2011-11-07 21:54 UTC | newest] Thread overview: 11+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2011-11-03 14:07 sb_edac 32-bit compile fail due to 64-bit divide Josh Boyer 2011-11-03 14:32 ` Mauro Carvalho Chehab 2011-11-03 14:43 ` Josh Boyer 2011-11-03 16:31 ` Luck, Tony 2011-11-03 17:41 ` Mauro Carvalho Chehab 2011-11-03 17:48 ` Josh Boyer 2011-11-03 17:51 ` Mauro Carvalho Chehab 2011-11-03 17:20 ` Mauro Carvalho Chehab 2011-11-07 21:29 ` [PATCH] Fix sb_edac compilation with 32 bits kernels Mauro Carvalho Chehab 2011-11-07 21:37 ` Josh Boyer 2011-11-07 21:54 ` Mauro Carvalho Chehab
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox