[llvm] [mlir] [mlir python] Port in-tree dialects to nanobind. (PR #119924)

Stella Laurenzo via llvm-commits llvm-commits at lists.llvm.org
Wed Dec 25 00:22:18 PST 2024


stellaraccident wrote:

> FYI after upgrading `mlir-python-extras` to latest I am suddenly getting this:
> 
> ```
> nanobind: leaked 3 instances!
>  - leaked instance 0x7fe74e5c1c88 of type "mlir.execution_engine.ExecutionEngine"
>  - leaked instance 0x7fe74e5ba868 of type "mlir._mlir_libs._mlir.ir.UnrankedMemRefType"
>  - leaked instance 0x7fe74e67afa8 of type "mlir._mlir_libs.Context"
> nanobind: leaked 126 types!
>  - leaked type "mlir._mlir_libs._mlir.ir.AffineFloorDivExpr"
>  - leaked type "mlir._mlir_libs._mlir.ir.AffineCeilDivExpr"
>  - leaked type "mlir._mlir_libs._mlir.ir.F16Type"
>  - leaked type "mlir._mlir_libs._mlir.ir.AffineMap"
>  - leaked type "mlir._mlir_libs._mlirExecutionEngine.ExecutionEngine"
>  - leaked type "mlir._mlir_libs._mlir.ir.FloatTF32Type"
>  - leaked type "mlir._mlir_libs._mlir.ir.Float8E8M0FNUType"
>  - leaked type "mlir._mlir_libs._mlir.ir.IntegerAttr"
>  - leaked type "mlir._mlir_libs._mlir.ir.OpOperandIterator"
>  - leaked type "mlir._mlir_libs._mlir.ir.OpView"
>  - leaked type "mlir._mlir_libs._mlir.passmanager.PassManager"
>  - ... skipped remainder
> nanobind: leaked 860 functions!
>  - leaked function "__init__"
>  - leaked function ""
>  - leaked function ""
>  - leaked function ""
>  - leaked function "dump"
>  - leaked function "get_identity"
>  - leaked function "__add__"
>  - leaked function "maybe_downcast"
>  - leaked function "__init__"
>  - leaked function ""
>  - leaked function ""
>  - ... skipped remainder
> nanobind: this is likely caused by a reference counting issue in the binding code.
> ```
> 
> I'm not sure if this is my fault or upstream's 🤷

I've generally found the nanobind leak detector to make false positive warnings in a variety of situations that are common in these kind of programs. I can't tell if this is one of them. There is a function you can call at module init or after to silence it. I'd recommend landing that upstream while investigating. 

TBH - the only reliable way I've found to do leak detection is via a python debug build (which explicitly frees at shutdown) and ASAN. Anything else is easily thwarted with valid programs.

https://github.com/llvm/llvm-project/pull/119924


More information about the llvm-commits mailing list