drm/nouveau/clk: fix gcc-7 -Wint-in-bool-context warning
gcc thinks that interpreting a multiplication result as a bool is confusing: drivers/gpu/drm/nouveau/nvkm/subdev/clk/gt215.c: In function 'read_pll': drivers/gpu/drm/nouveau/nvkm/subdev/clk/gt215.c:133:8: error: '*' in boolean context, suggest '&&' instead [-Werror=int-in-bool-context] Adding a temporary variable to contain the divisor helps make it clear what is going on and avoids that warning. Signed-off-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
This commit is contained in:
parent
e64fe9db2d
commit
b515483e12
@ -110,6 +110,7 @@ read_pll(struct gt215_clk *clk, int idx, u32 pll)
|
|||||||
struct nvkm_device *device = clk->base.subdev.device;
|
struct nvkm_device *device = clk->base.subdev.device;
|
||||||
u32 ctrl = nvkm_rd32(device, pll + 0);
|
u32 ctrl = nvkm_rd32(device, pll + 0);
|
||||||
u32 sclk = 0, P = 1, N = 1, M = 1;
|
u32 sclk = 0, P = 1, N = 1, M = 1;
|
||||||
|
u32 MP;
|
||||||
|
|
||||||
if (!(ctrl & 0x00000008)) {
|
if (!(ctrl & 0x00000008)) {
|
||||||
if (ctrl & 0x00000001) {
|
if (ctrl & 0x00000001) {
|
||||||
@ -130,10 +131,12 @@ read_pll(struct gt215_clk *clk, int idx, u32 pll)
|
|||||||
sclk = read_clk(clk, 0x10 + idx, false);
|
sclk = read_clk(clk, 0x10 + idx, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (M * P)
|
MP = M * P;
|
||||||
return sclk * N / (M * P);
|
|
||||||
|
|
||||||
return 0;
|
if (!MP)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return sclk * N / MP;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
Loading…
Reference in New Issue
Block a user