Hello Shawn Lin, The patch cf590b078391: "PCI: rockchip: Add EP driver for Rockchip PCIe controller" from May 9, 2018, leads to the following static checker warning: drivers/pci/controller/pcie-rockchip-ep.c:380 rockchip_pcie_ep_assert_intx() warn: '(1 << (19))' 524288 can't fit into 65535 'status' drivers/pci/controller/pcie-rockchip-ep.c 347 static void rockchip_pcie_ep_assert_intx(struct rockchip_pcie_ep *ep, u8 fn, 348 u8 intx, bool is_asserted) 349 { 350 struct rockchip_pcie *rockchip = &ep->rockchip; 351 u32 r = ep->max_regions - 1; 352 u32 offset; 353 u16 status; 354 u8 msg_code; 355 356 if (unlikely(ep->irq_pci_addr != ROCKCHIP_PCIE_EP_PCI_LEGACY_IRQ_ADDR || 357 ep->irq_pci_fn != fn)) { 358 rockchip_pcie_prog_ep_ob_atu(rockchip, fn, r, 359 AXI_WRAPPER_NOR_MSG, 360 ep->irq_phys_addr, 0, 0); 361 ep->irq_pci_addr = ROCKCHIP_PCIE_EP_PCI_LEGACY_IRQ_ADDR; 362 ep->irq_pci_fn = fn; 363 } 364 365 intx &= 3; 366 if (is_asserted) { 367 ep->irq_pending |= BIT(intx); 368 msg_code = ROCKCHIP_PCIE_MSG_CODE_ASSERT_INTA + intx; 369 } else { 370 ep->irq_pending &= ~BIT(intx); 371 msg_code = ROCKCHIP_PCIE_MSG_CODE_DEASSERT_INTA + intx; 372 } 373 374 status = rockchip_pcie_read(rockchip, 375 ROCKCHIP_PCIE_EP_FUNC_BASE(fn) + 376 ROCKCHIP_PCIE_EP_CMD_STATUS); 377 status &= ROCKCHIP_PCIE_EP_CMD_STATUS_IS; 378 379 if ((status != 0) ^ (ep->irq_pending != 0)) { 380 status ^= ROCKCHIP_PCIE_EP_CMD_STATUS_IS; ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ status is a u16 but we're twiddling BIT(19). 381 rockchip_pcie_write(rockchip, status, 382 ROCKCHIP_PCIE_EP_FUNC_BASE(fn) + 383 ROCKCHIP_PCIE_EP_CMD_STATUS); 384 } 385 386 offset = 387 ROCKCHIP_PCIE_MSG_ROUTING(ROCKCHIP_PCIE_MSG_ROUTING_LOCAL_INTX) | 388 ROCKCHIP_PCIE_MSG_CODE(msg_code) | ROCKCHIP_PCIE_MSG_NO_DATA; 389 writel(0, ep->irq_cpu_addr + offset); 390 } regards, dan carpenter _______________________________________________ Linux-rockchip mailing list Linux-rockchip@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/linux-rockchip