summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYee Cheng Chin <ychin.git@gmail.com>2023-09-19 20:30:22 +0200
committerChristian Brabandt <cb@256bit.org>2023-09-19 20:30:22 +0200
commit2ce070c27acd12ccc614afa4cecf4970a645a4af (patch)
tree2c8287ac4450e0fc6924c851ee59eb93f6863417
parent6f00d17e8d64ed46c85625e8ac38ed0928b32c58 (diff)
patch 9.0.1913: if_python: undefined behaviour for function pointersv9.0.1913
Problem: if_python: undefined behaviour for function pointers Solution: Fix if_python undefined behavior for function pointer casts Identified by clang 17 UBSAN (see #12745). Make sure to cast function pointers with the same signature only. closes: #13122 Signed-off-by: Christian Brabandt <cb@256bit.org> Co-authored-by: Yee Cheng Chin <ychin.git@gmail.com>
-rw-r--r--src/if_py_both.h5
-rw-r--r--src/if_python.c8
-rw-r--r--src/if_python3.c8
-rw-r--r--src/version.c2
4 files changed, 13 insertions, 10 deletions
diff --git a/src/if_py_both.h b/src/if_py_both.h
index 6e2ef26e7d..0723a5ff9b 100644
--- a/src/if_py_both.h
+++ b/src/if_py_both.h
@@ -5962,14 +5962,15 @@ static struct PyMethodDef CurrentMethods[] = {
};
static void
-init_range_cmd(exarg_T *eap)
+init_range_cmd(void *arg)
{
+ exarg_T *eap = (exarg_T*)arg;
RangeStart = eap->line1;
RangeEnd = eap->line2;
}
static void
-init_range_eval(typval_T *rettv UNUSED)
+init_range_eval(void *rettv UNUSED)
{
RangeStart = (PyInt) curwin->w_cursor.lnum;
RangeEnd = RangeStart;
diff --git a/src/if_python.c b/src/if_python.c
index 863e9319df..c6b14fec27 100644
--- a/src/if_python.c
+++ b/src/if_python.c
@@ -1103,7 +1103,7 @@ ex_python(exarg_T *eap)
p_pyx = 2;
DoPyCommand(script == NULL ? (char *) eap->arg : (char *) script,
- (rangeinitializer) init_range_cmd,
+ init_range_cmd,
(runner) run_cmd,
(void *) eap);
}
@@ -1154,7 +1154,7 @@ ex_pyfile(exarg_T *eap)
// Execute the file
DoPyCommand(buffer,
- (rangeinitializer) init_range_cmd,
+ init_range_cmd,
(runner) run_cmd,
(void *) eap);
}
@@ -1166,7 +1166,7 @@ ex_pydo(exarg_T *eap)
p_pyx = 2;
DoPyCommand((char *)eap->arg,
- (rangeinitializer) init_range_cmd,
+ init_range_cmd,
(runner)run_do,
(void *)eap);
}
@@ -1524,7 +1524,7 @@ FunctionGetattr(PyObject *self, char *name)
do_pyeval(char_u *str, typval_T *rettv)
{
DoPyCommand((char *) str,
- (rangeinitializer) init_range_eval,
+ init_range_eval,
(runner) run_eval,
(void *) rettv);
if (rettv->v_type == VAR_UNKNOWN)
diff --git a/src/if_python3.c b/src/if_python3.c
index c6d1acc198..d2ffada0c4 100644
--- a/src/if_python3.c
+++ b/src/if_python3.c
@@ -1425,7 +1425,7 @@ ex_py3(exarg_T *eap)
p_pyx = 3;
DoPyCommand(script == NULL ? (char *) eap->arg : (char *) script,
- (rangeinitializer) init_range_cmd,
+ init_range_cmd,
(runner) run_cmd,
(void *) eap);
}
@@ -1491,7 +1491,7 @@ ex_py3file(exarg_T *eap)
// Execute the file
DoPyCommand(buffer,
- (rangeinitializer) init_range_cmd,
+ init_range_cmd,
(runner) run_cmd,
(void *) eap);
}
@@ -1503,7 +1503,7 @@ ex_py3do(exarg_T *eap)
p_pyx = 3;
DoPyCommand((char *)eap->arg,
- (rangeinitializer)init_range_cmd,
+ init_range_cmd,
(runner)run_do,
(void *)eap);
}
@@ -2053,7 +2053,7 @@ LineToString(const char *str)
do_py3eval(char_u *str, typval_T *rettv)
{
DoPyCommand((char *) str,
- (rangeinitializer) init_range_eval,
+ init_range_eval,
(runner) run_eval,
(void *) rettv);
if (rettv->v_type == VAR_UNKNOWN)
diff --git a/src/version.c b/src/version.c
index 42ac8083b0..c43b28f373 100644
--- a/src/version.c
+++ b/src/version.c
@@ -700,6 +700,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1913,
+/**/
1912,
/**/
1911,