mirror of https://gitee.com/openkylin/linux.git
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;
|
||||
u32 ctrl = nvkm_rd32(device, pll + 0);
|
||||
u32 sclk = 0, P = 1, N = 1, M = 1;
|
||||
u32 MP;
|
||||
|
||||
if (!(ctrl & 0x00000008)) {
|
||||
if (ctrl & 0x00000001) {
|
||||
|
@ -130,10 +131,12 @@ read_pll(struct gt215_clk *clk, int idx, u32 pll)
|
|||
sclk = read_clk(clk, 0x10 + idx, false);
|
||||
}
|
||||
|
||||
if (M * P)
|
||||
return sclk * N / (M * P);
|
||||
MP = M * P;
|
||||
|
||||
return 0;
|
||||
if (!MP)
|
||||
return 0;
|
||||
|
||||
return sclk * N / MP;
|
||||
}
|
||||
|
||||
static int
|
||||
|
|
Loading…
Reference in New Issue