diff options
Diffstat (limited to 'py/pykms')
-rw-r--r-- | py/pykms/__init__.py | 2 | ||||
-rw-r--r-- | py/pykms/pykms.cpp | 5 | ||||
-rw-r--r-- | py/pykms/pykmsbase.cpp | 18 |
3 files changed, 7 insertions, 18 deletions
diff --git a/py/pykms/__init__.py b/py/pykms/__init__.py index 3b5f743..746c917 100644 --- a/py/pykms/__init__.py +++ b/py/pykms/__init__.py @@ -130,7 +130,7 @@ def __card_read_events(self): seq = vbl_tuple[3] time = vbl_tuple[1] + vbl_tuple[2] / 1000000.0; - udata = pykms.__ob_unpack_helper(vbl_tuple[0]) + udata = vbl_tuple[0] yield DrmEvent(type, seq, time, udata) diff --git a/py/pykms/pykms.cpp b/py/pykms/pykms.cpp index 7752f19..1e54c9b 100644 --- a/py/pykms/pykms.cpp +++ b/py/pykms/pykms.cpp @@ -20,11 +20,6 @@ PYBIND11_PLUGIN(pykms) { init_pykmsbase(m); - m.def("__ob_unpack_helper", [](uint64_t v) { - // AtomicReq::commit or Crtc::page_flip added a ref, so we can use borrowed = false - return py::object((PyObject*)v, false); - }); - init_pykmstest(m); init_pyvid(m); diff --git a/py/pykms/pykmsbase.cpp b/py/pykms/pykmsbase.cpp index 604e07c..e53fe54 100644 --- a/py/pykms/pykmsbase.cpp +++ b/py/pykms/pykmsbase.cpp @@ -53,13 +53,10 @@ void init_pykmsbase(py::module &m) .def("set_mode", &Crtc::set_mode) .def("disable_mode", &Crtc::disable_mode) .def("page_flip", - [](Crtc* self, Framebuffer& fb, py::object ob) + [](Crtc* self, Framebuffer& fb, uint32_t data) { - // This adds a ref to the object, and must be unpacked with __ob_unpack_helper() - PyObject* pob = ob.ptr(); - Py_XINCREF(pob); - self->page_flip(fb, pob); - }) + self->page_flip(fb, (void*)(intptr_t)data); + }, py::arg("fb"), py::arg("data") = 0) .def("set_plane", &Crtc::set_plane) .def_property_readonly("possible_planes", &Crtc::get_possible_planes) .def_property_readonly("primary_plane", &Crtc::get_primary_plane) @@ -196,13 +193,10 @@ void init_pykmsbase(py::module &m) .def("add", (void (AtomicReq::*)(DrmPropObject*, const map<string, uint64_t>&)) &AtomicReq::add) .def("test", &AtomicReq::test, py::arg("allow_modeset") = false) .def("commit", - [](AtomicReq* self, py::object ob, bool allow) + [](AtomicReq* self, uint32_t data, bool allow) { - // This adds a ref to the object, and must be unpacked with __ob_unpack_helper() - PyObject* pob = ob.ptr(); - Py_XINCREF(pob); - return self->commit(pob, allow); - }, py::arg("data"), py::arg("allow_modeset") = false) + return self->commit((void*)(intptr_t)data, allow); + }, py::arg("data") = 0, py::arg("allow_modeset") = false) .def("commit_sync", &AtomicReq::commit_sync, py::arg("allow_modeset") = false) ; } |