提交 57be046e 编写于 作者: I Ilia Mirkin 提交者: Ben Skeggs

drm/nouveau/core: get rid of math.h, replace log2i with order_base_2

Signed-off-by: NIlia Mirkin <imirkin@alum.mit.edu>
Signed-off-by: NBen Skeggs <bskeggs@redhat.com>
上级 ef25bd84
...@@ -22,7 +22,6 @@ ...@@ -22,7 +22,6 @@
#include <core/object.h> #include <core/object.h>
#include <core/ramht.h> #include <core/ramht.h>
#include <core/math.h>
#include <subdev/bar.h> #include <subdev/bar.h>
...@@ -104,6 +103,6 @@ nouveau_ramht_new(struct nouveau_object *parent, struct nouveau_object *pargpu, ...@@ -104,6 +103,6 @@ nouveau_ramht_new(struct nouveau_object *parent, struct nouveau_object *pargpu,
if (ret) if (ret)
return ret; return ret;
ramht->bits = log2i(nv_gpuobj(ramht)->size >> 3); ramht->bits = order_base_2(nv_gpuobj(ramht)->size >> 3);
return 0; return 0;
} }
...@@ -26,7 +26,6 @@ ...@@ -26,7 +26,6 @@
#include <core/engctx.h> #include <core/engctx.h>
#include <core/ramht.h> #include <core/ramht.h>
#include <core/class.h> #include <core/class.h>
#include <core/math.h>
#include <subdev/timer.h> #include <subdev/timer.h>
#include <subdev/bar.h> #include <subdev/bar.h>
...@@ -278,7 +277,7 @@ nv50_fifo_chan_ctor_ind(struct nouveau_object *parent, ...@@ -278,7 +277,7 @@ nv50_fifo_chan_ctor_ind(struct nouveau_object *parent,
return ret; return ret;
ioffset = args->ioffset; ioffset = args->ioffset;
ilength = log2i(args->ilength / 8); ilength = order_base_2(args->ilength / 8);
nv_wo32(base->ramfc, 0x3c, 0x403f6078); nv_wo32(base->ramfc, 0x3c, 0x403f6078);
nv_wo32(base->ramfc, 0x44, 0x01003fff); nv_wo32(base->ramfc, 0x44, 0x01003fff);
......
...@@ -28,7 +28,6 @@ ...@@ -28,7 +28,6 @@
#include <core/ramht.h> #include <core/ramht.h>
#include <core/event.h> #include <core/event.h>
#include <core/class.h> #include <core/class.h>
#include <core/math.h>
#include <subdev/timer.h> #include <subdev/timer.h>
#include <subdev/bar.h> #include <subdev/bar.h>
...@@ -258,7 +257,7 @@ nv84_fifo_chan_ctor_ind(struct nouveau_object *parent, ...@@ -258,7 +257,7 @@ nv84_fifo_chan_ctor_ind(struct nouveau_object *parent,
nv_parent(chan)->object_detach = nv50_fifo_object_detach; nv_parent(chan)->object_detach = nv50_fifo_object_detach;
ioffset = args->ioffset; ioffset = args->ioffset;
ilength = log2i(args->ilength / 8); ilength = order_base_2(args->ilength / 8);
nv_wo32(base->ramfc, 0x3c, 0x403f6078); nv_wo32(base->ramfc, 0x3c, 0x403f6078);
nv_wo32(base->ramfc, 0x44, 0x01003fff); nv_wo32(base->ramfc, 0x44, 0x01003fff);
......
...@@ -29,7 +29,6 @@ ...@@ -29,7 +29,6 @@
#include <core/engctx.h> #include <core/engctx.h>
#include <core/event.h> #include <core/event.h>
#include <core/class.h> #include <core/class.h>
#include <core/math.h>
#include <core/enum.h> #include <core/enum.h>
#include <subdev/timer.h> #include <subdev/timer.h>
...@@ -200,7 +199,7 @@ nvc0_fifo_chan_ctor(struct nouveau_object *parent, ...@@ -200,7 +199,7 @@ nvc0_fifo_chan_ctor(struct nouveau_object *parent,
usermem = chan->base.chid * 0x1000; usermem = chan->base.chid * 0x1000;
ioffset = args->ioffset; ioffset = args->ioffset;
ilength = log2i(args->ilength / 8); ilength = order_base_2(args->ilength / 8);
for (i = 0; i < 0x1000; i += 4) for (i = 0; i < 0x1000; i += 4)
nv_wo32(priv->user.mem, usermem + i, 0x00000000); nv_wo32(priv->user.mem, usermem + i, 0x00000000);
......
...@@ -29,7 +29,6 @@ ...@@ -29,7 +29,6 @@
#include <core/engctx.h> #include <core/engctx.h>
#include <core/event.h> #include <core/event.h>
#include <core/class.h> #include <core/class.h>
#include <core/math.h>
#include <core/enum.h> #include <core/enum.h>
#include <subdev/timer.h> #include <subdev/timer.h>
...@@ -240,7 +239,7 @@ nve0_fifo_chan_ctor(struct nouveau_object *parent, ...@@ -240,7 +239,7 @@ nve0_fifo_chan_ctor(struct nouveau_object *parent,
usermem = chan->base.chid * 0x200; usermem = chan->base.chid * 0x200;
ioffset = args->ioffset; ioffset = args->ioffset;
ilength = log2i(args->ilength / 8); ilength = order_base_2(args->ilength / 8);
for (i = 0; i < 0x200; i += 4) for (i = 0; i < 0x200; i += 4)
nv_wo32(priv->user.mem, usermem + i, 0x00000000); nv_wo32(priv->user.mem, usermem + i, 0x00000000);
......
#ifndef __NOUVEAU_MATH_H__
#define __NOUVEAU_MATH_H__
static inline int
log2i(u64 base)
{
u64 temp = base >> 1;
int log2;
for (log2 = 0; temp; log2++, temp >>= 1) {
}
return (base & (base - 1)) ? log2 + 1: log2;
}
#endif
...@@ -13,11 +13,12 @@ ...@@ -13,11 +13,12 @@
#include <linux/i2c-algo-bit.h> #include <linux/i2c-algo-bit.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/io-mapping.h> #include <linux/io-mapping.h>
#include <linux/vmalloc.h>
#include <linux/acpi.h> #include <linux/acpi.h>
#include <linux/vmalloc.h>
#include <linux/dmi.h> #include <linux/dmi.h>
#include <linux/reboot.h> #include <linux/reboot.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/log2.h>
#include <asm/unaligned.h> #include <asm/unaligned.h>
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册