summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexandre Courbot <acourbot@nvidia.com>2016-09-16 18:09:12 +0900
committerBen Skeggs <bskeggs@redhat.com>2016-11-04 17:17:05 +1000
commit26735c44da7a2de18d66fe63507a9c4863ebd719 (patch)
treea46cd8fc94d567b8b264fa6e713fe14a43d6a66d
parent6fa1704bb55f7e9bc31a46989791c56a3c9f76e6 (diff)
downloadnouveau-26735c44da7a2de18d66fe63507a9c4863ebd719.tar.gz
volt: use kernel's 64-bit signed division function
Doing direct 64 bit divisions in kernel code leads to references to undefined symbols on 32 bit architectures. Replace such divisions with calls to div64_s64 to make the module usable on 32 bit archs. Signed-off-by: Alexandre Courbot <acourbot@nvidia.com> Reviewed-by: Karol Herbst <karolherbst@gmail.com> Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
-rw-r--r--drm/nouveau/nvkm/subdev/volt/base.c6
-rw-r--r--lib/include/nvif/os.h1
2 files changed, 4 insertions, 3 deletions
diff --git a/drm/nouveau/nvkm/subdev/volt/base.c b/drm/nouveau/nvkm/subdev/volt/base.c
index 90d234231..e8569b04b 100644
--- a/drm/nouveau/nvkm/subdev/volt/base.c
+++ b/drm/nouveau/nvkm/subdev/volt/base.c
@@ -116,9 +116,9 @@ nvkm_volt_map(struct nvkm_volt *volt, u8 id, u8 temp)
return volt->speedo;
if (ver == 0x10 || (ver == 0x20 && info.mode == 0)) {
- result = (s64)info.arg[0] / 10;
- result += ((s64)info.arg[1] * volt->speedo) / 10;
- result += ((s64)info.arg[2] * volt->speedo * volt->speedo) / 100000;
+ result = div64_s64((s64)info.arg[0], 10);
+ result += div64_s64((s64)info.arg[1] * volt->speedo, 10);
+ result += div64_s64((s64)info.arg[2] * volt->speedo * volt->speedo, 100000);
} else if (ver == 0x20) {
switch (info.mode) {
/* 0x0 handled above! */
diff --git a/lib/include/nvif/os.h b/lib/include/nvif/os.h
index 2f34c5a28..c10c29f33 100644
--- a/lib/include/nvif/os.h
+++ b/lib/include/nvif/os.h
@@ -88,6 +88,7 @@ typedef dma_addr_t resource_size_t;
)
#define do_div(a,b) (a) = (a) / (b)
#define div_u64(a,b) (a) / (b)
+#define div64_s64(a,b) (a) / (b)
#define likely(a) (a)
#define unlikely(a) (a)
#define BIT(a) (1UL << (a))