]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
perf python: Stop using deprecated PyUnicode_AsString()
authorArnaldo Carvalho de Melo <acme@kernel.org>
Wed, 30 Jul 2025 13:34:20 +0000 (10:34 -0300)
committerNamhyung Kim <namhyung@kernel.org>
Wed, 30 Jul 2025 17:15:17 +0000 (10:15 -0700)
As noticed while building for Fedora 43:

    GEN     /tmp/build/perf/python/perf.cpython-314-x86_64-linux-gnu.so
  /git/perf-6.16.0-rc3/tools/perf/util/python.c: In function ‘get_tracepoint_field’:
  /git/perf-6.16.0-rc3/tools/perf/util/python.c:340:9: error: ‘_PyUnicode_AsString’ is deprecated [-Werror=deprecated-declarations]
    340 |         const char *str = _PyUnicode_AsString(PyObject_Str(attr_name));
        |         ^~~~~
  In file included from /usr/include/python3.14/unicodeobject.h:1022,
                   from /usr/include/python3.14/Python.h:89,
                   from /git/perf-6.16.0-rc3/tools/perf/util/python.c:2:
  /usr/include/python3.14/cpython/unicodeobject.h:648:1: note: declared here
    648 | _PyUnicode_AsString(PyObject *unicode)
        | ^~~~~~~~~~~~~~~~~~~
  cc1: all warnings being treated as errors
  error: command '/usr/bin/gcc' failed with exit code 1

Use PyUnicode_AsUTF8() instead and also check if PyObject_Str() fails
before doing so.

Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Link: https://lore.kernel.org/r/aIofXNK8QLtLIaI3@x1
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
tools/perf/util/python.c

index 2f28f71325a87a2dc377631af871fc25ab0b9820..ea77bea0306fa08dcf9dddb4482e84f22fcc63c6 100644 (file)
@@ -337,7 +337,6 @@ tracepoint_field(const struct pyrf_event *pe, struct tep_format_field *field)
 static PyObject*
 get_tracepoint_field(struct pyrf_event *pevent, PyObject *attr_name)
 {
-       const char *str = _PyUnicode_AsString(PyObject_Str(attr_name));
        struct evsel *evsel = pevent->evsel;
        struct tep_event *tp_format = evsel__tp_format(evsel);
        struct tep_format_field *field;
@@ -345,7 +344,18 @@ get_tracepoint_field(struct pyrf_event *pevent, PyObject *attr_name)
        if (IS_ERR_OR_NULL(tp_format))
                return NULL;
 
+       PyObject *obj = PyObject_Str(attr_name);
+       if (obj == NULL)
+               return NULL;
+
+       const char *str = PyUnicode_AsUTF8(obj);
+       if (str == NULL) {
+               Py_DECREF(obj);
+               return NULL;
+       }
+
        field = tep_find_any_field(tp_format, str);
+       Py_DECREF(obj);
        return field ? tracepoint_field(pevent, field) : NULL;
 }
 #endif /* HAVE_LIBTRACEEVENT */