diff --git a/src/lua_baselib.c b/src/lua_baselib.c
index 58c7c80a3c1e50cd62b0c82bde80a6363d635e08..3e1f2c2dde1469513b3fb4bacf1f3d16aadb24f5 100644
--- a/src/lua_baselib.c
+++ b/src/lua_baselib.c
@@ -935,6 +935,17 @@ static int lib_pRingXYMovement(lua_State *L)
 	return 0;
 }
 
+static int lib_pSceneryXYMovement(lua_State *L)
+{
+	mobj_t *actor = *((mobj_t **)luaL_checkudata(L, 1, META_MOBJ));
+	NOHUD
+	INLEVEL
+	if (!actor)
+		return LUA_ErrInvalid(L, "mobj_t");
+	P_SceneryXYMovement(actor);
+	return 0;
+}
+
 // P_USER
 ////////////
 
@@ -3295,6 +3306,7 @@ static luaL_Reg lib[] = {
 	{"P_RailThinker",lib_pRailThinker},
 	{"P_XYMovement",lib_pXYMovement},
 	{"P_RingXYMovement",lib_pRingXYMovement},
+	{"P_SceneryXYMovement",lib_pSceneryXYMovement},
 
 	// p_user
 	{"P_GetPlayerHeight",lib_pGetPlayerHeight},
diff --git a/src/p_mobj.c b/src/p_mobj.c
index 9d6efd950ad7a49c27633a62c49268790390d2ad..a6886c1add224f070bd92646fdc9a22197e467c3 100644
--- a/src/p_mobj.c
+++ b/src/p_mobj.c
@@ -2111,7 +2111,7 @@ void P_RingXYMovement(mobj_t *mo)
 		P_SlideMove(mo);
 }
 
-static void P_SceneryXYMovement(mobj_t *mo)
+void P_SceneryXYMovement(mobj_t *mo)
 {
 	fixed_t oldx, oldy; // reducing bobbing/momentum on ice when up against walls
 
diff --git a/src/p_mobj.h b/src/p_mobj.h
index d874ffe09c5f1011b5efc97a3744df17a541a8d2..99d09176097027c29626f5bca886c373997cf9c2 100644
--- a/src/p_mobj.h
+++ b/src/p_mobj.h
@@ -472,6 +472,7 @@ void P_RemovePrecipMobj(precipmobj_t *mobj);
 void P_SetScale(mobj_t *mobj, fixed_t newscale);
 void P_XYMovement(mobj_t *mo);
 void P_RingXYMovement(mobj_t *mo);
+void P_SceneryXYMovement(mobj_t *mo);
 void P_EmeraldManager(void);
 
 extern INT32 modulothing;