Commit 4bbca788 authored by Hans de Goede's avatar Hans de Goede Committed by Mauro Carvalho Chehab

media: atomisp: remove private acceleration ioctls

These ioctls allow userspace to load custom programs into the ISP, which:

a) Seems dangerous
b) Cannot be used by opensource userspace since there is no FOSS code to
   create such programs
b) These seem to be unused even by the Android closed source camera code
   (they don't show up in a strace of the camera app)

So removing these seems be a good idea. Another reason to remove these is
that atomisp_acc_map() is the only user of the userptr functionality in
hmm_alloc(), so it gets in the way of further cleanups / simplification
of the hmm code.

Link: https://lore.kernel.org/linux-media/20220615205037.16549-19-hdegoede@redhat.comReviewed-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent 5c915294
......@@ -740,24 +740,6 @@ enum atomisp_frame_status {
ATOMISP_FRAME_STATUS_FLASH_FAILED,
};
enum atomisp_acc_type {
ATOMISP_ACC_STANDALONE, /* Stand-alone acceleration */
ATOMISP_ACC_OUTPUT, /* Accelerator stage on output frame */
ATOMISP_ACC_VIEWFINDER /* Accelerator stage on viewfinder frame */
};
enum atomisp_acc_arg_type {
ATOMISP_ACC_ARG_SCALAR_IN, /* Scalar input argument */
ATOMISP_ACC_ARG_SCALAR_OUT, /* Scalar output argument */
ATOMISP_ACC_ARG_SCALAR_IO, /* Scalar in/output argument */
ATOMISP_ACC_ARG_PTR_IN, /* Pointer input argument */
ATOMISP_ACC_ARG_PTR_OUT, /* Pointer output argument */
ATOMISP_ACC_ARG_PTR_IO, /* Pointer in/output argument */
ATOMISP_ARG_PTR_NOFLUSH, /* Pointer argument will not be flushed */
ATOMISP_ARG_PTR_STABLE, /* Pointer input argument that is stable */
ATOMISP_ACC_ARG_FRAME /* Frame argument */
};
/* ISP memories, isp2400 */
enum atomisp_acc_memory {
ATOMISP_ACC_MEMORY_PMEM0 = 0,
......@@ -836,56 +818,6 @@ enum atomisp_burst_capture_options {
#define EXT_ISP_SHOT_MODE_ANIMATED_PHOTO 10
#define EXT_ISP_SHOT_MODE_SPORTS 11
struct atomisp_sp_arg {
enum atomisp_acc_arg_type type; /* Type of SP argument */
void *value; /* Value of SP argument */
unsigned int size; /* Size of SP argument */
};
/* Acceleration API */
/* For CSS 1.0 only */
struct atomisp_acc_fw_arg {
unsigned int fw_handle;
unsigned int index;
void __user *value;
size_t size;
};
/*
* Set arguments after first mapping with ATOMISP_IOC_ACC_S_MAPPED_ARG.
*/
struct atomisp_acc_s_mapped_arg {
unsigned int fw_handle;
__u32 memory; /* one of enum atomisp_acc_memory */
size_t length;
unsigned long css_ptr;
};
struct atomisp_acc_fw_abort {
unsigned int fw_handle;
/* Timeout in us */
unsigned int timeout;
};
struct atomisp_acc_fw_load {
unsigned int size;
unsigned int fw_handle;
void __user *data;
};
/*
* Load firmware to specified pipeline.
*/
struct atomisp_acc_fw_load_to_pipe {
__u32 flags; /* Flags, see below for valid values */
unsigned int fw_handle; /* Handle, filled by kernel. */
__u32 size; /* Firmware binary size */
void __user *data; /* Pointer to firmware */
__u32 type; /* Binary type */
__u32 reserved[3]; /* Set to zero */
};
/*
* Set Senor run mode
*/
......@@ -905,24 +837,10 @@ struct atomisp_s_runmode {
#define ATOMISP_ACC_FW_LOAD_TYPE_VIEWFINDER 2 /* Stage on viewfinder */
#define ATOMISP_ACC_FW_LOAD_TYPE_STANDALONE 3 /* Stand-alone acceleration */
struct atomisp_acc_map {
__u32 flags; /* Flags, see list below */
__u32 length; /* Length of data in bytes */
void __user *user_ptr; /* Pointer into user space */
unsigned long css_ptr; /* Pointer into CSS address space */
__u32 reserved[4]; /* Set to zero */
};
#define ATOMISP_MAP_FLAG_NOFLUSH 0x0001 /* Do not flush cache */
#define ATOMISP_MAP_FLAG_CACHED 0x0002 /* Enable cache */
#define ATOMISP_MAP_FLAG_CLEARED 0x0004
struct atomisp_acc_state {
__u32 flags; /* Flags, see list below */
#define ATOMISP_STATE_FLAG_ENABLE ATOMISP_ACC_FW_LOAD_FL_ENABLE
unsigned int fw_handle;
};
struct atomisp_update_exposure {
unsigned int gain;
unsigned int digi_gain;
......@@ -1090,29 +1008,6 @@ struct atomisp_sensor_ae_bracketing_lut {
#define ATOMISP_IOC_S_3A_CONFIG \
_IOW('v', BASE_VIDIOC_PRIVATE + 23, struct atomisp_3a_config)
/* Accelerate ioctls */
#define ATOMISP_IOC_ACC_LOAD \
_IOWR('v', BASE_VIDIOC_PRIVATE + 24, struct atomisp_acc_fw_load)
#define ATOMISP_IOC_ACC_UNLOAD \
_IOWR('v', BASE_VIDIOC_PRIVATE + 24, unsigned int)
/* For CSS 1.0 only */
#define ATOMISP_IOC_ACC_S_ARG \
_IOW('v', BASE_VIDIOC_PRIVATE + 24, struct atomisp_acc_fw_arg)
#define ATOMISP_IOC_ACC_START \
_IOW('v', BASE_VIDIOC_PRIVATE + 24, unsigned int)
#define ATOMISP_IOC_ACC_WAIT \
_IOW('v', BASE_VIDIOC_PRIVATE + 25, unsigned int)
#define ATOMISP_IOC_ACC_ABORT \
_IOW('v', BASE_VIDIOC_PRIVATE + 25, struct atomisp_acc_fw_abort)
#define ATOMISP_IOC_ACC_DESTAB \
_IOW('v', BASE_VIDIOC_PRIVATE + 25, struct atomisp_acc_fw_arg)
/* sensor OTP memory read */
#define ATOMISP_IOC_G_SENSOR_PRIV_INT_DATA \
_IOWR('v', BASE_VIDIOC_PRIVATE + 26, struct v4l2_private_int_data)
......@@ -1132,24 +1027,6 @@ struct atomisp_sensor_ae_bracketing_lut {
#define ATOMISP_IOC_G_MOTOR_PRIV_INT_DATA \
_IOWR('v', BASE_VIDIOC_PRIVATE + 29, struct v4l2_private_int_data)
/*
* Ioctls to map and unmap user buffers to CSS address space for acceleration.
* User fills fields length and user_ptr and sets other fields to zero,
* kernel may modify the flags and sets css_ptr.
*/
#define ATOMISP_IOC_ACC_MAP \
_IOWR('v', BASE_VIDIOC_PRIVATE + 30, struct atomisp_acc_map)
/* User fills fields length, user_ptr, and css_ptr and zeroes other fields. */
#define ATOMISP_IOC_ACC_UNMAP \
_IOW('v', BASE_VIDIOC_PRIVATE + 30, struct atomisp_acc_map)
#define ATOMISP_IOC_ACC_S_MAPPED_ARG \
_IOW('v', BASE_VIDIOC_PRIVATE + 30, struct atomisp_acc_s_mapped_arg)
#define ATOMISP_IOC_ACC_LOAD_TO_PIPE \
_IOWR('v', BASE_VIDIOC_PRIVATE + 31, struct atomisp_acc_fw_load_to_pipe)
#define ATOMISP_IOC_S_PARAMETERS \
_IOW('v', BASE_VIDIOC_PRIVATE + 32, struct atomisp_parameters)
......@@ -1183,12 +1060,6 @@ struct atomisp_sensor_ae_bracketing_lut {
#define ATOMISP_IOC_S_EXPOSURE_WINDOW \
_IOW('v', BASE_VIDIOC_PRIVATE + 40, struct atomisp_ae_window)
#define ATOMISP_IOC_S_ACC_STATE \
_IOW('v', BASE_VIDIOC_PRIVATE + 41, struct atomisp_acc_state)
#define ATOMISP_IOC_G_ACC_STATE \
_IOR('v', BASE_VIDIOC_PRIVATE + 41, struct atomisp_acc_state)
#define ATOMISP_IOC_INJECT_A_FAKE_EVENT \
_IOW('v', BASE_VIDIOC_PRIVATE + 42, int)
......
......@@ -41,52 +41,6 @@ void atomisp_acc_cleanup(struct atomisp_device *isp);
*/
void atomisp_acc_release(struct atomisp_sub_device *asd);
/* Load acceleration binary. DEPRECATED. */
int atomisp_acc_load(struct atomisp_sub_device *asd,
struct atomisp_acc_fw_load *fw);
/* Load acceleration binary with specified properties */
int atomisp_acc_load_to_pipe(struct atomisp_sub_device *asd,
struct atomisp_acc_fw_load_to_pipe *fw);
/* Unload specified acceleration binary */
int atomisp_acc_unload(struct atomisp_sub_device *asd,
unsigned int *handle);
/*
* Map a memory region into ISP memory space.
*/
int atomisp_acc_map(struct atomisp_sub_device *asd,
struct atomisp_acc_map *map);
/*
* Unmap a mapped memory region.
*/
int atomisp_acc_unmap(struct atomisp_sub_device *asd,
struct atomisp_acc_map *map);
/*
* Set acceleration binary argument to a previously mapped memory region.
*/
int atomisp_acc_s_mapped_arg(struct atomisp_sub_device *asd,
struct atomisp_acc_s_mapped_arg *arg);
/*
* Start acceleration.
* Return immediately, acceleration is left running in background.
* Specify either acceleration binary or pipeline which to start.
*/
int atomisp_acc_start(struct atomisp_sub_device *asd,
unsigned int *handle);
/*
* Wait until acceleration finishes.
* This MUST be called after each acceleration has been started.
* Specify either acceleration binary or pipeline handle.
*/
int atomisp_acc_wait(struct atomisp_sub_device *asd,
unsigned int *handle);
/*
* Used by ISR to notify ACC stage finished.
* This is internally used and does not export as IOCTL.
......@@ -105,16 +59,4 @@ int atomisp_acc_load_extensions(struct atomisp_sub_device *asd);
*/
void atomisp_acc_unload_extensions(struct atomisp_sub_device *asd);
/*
* Set acceleration firmware flags.
*/
int atomisp_acc_set_state(struct atomisp_sub_device *asd,
struct atomisp_acc_state *arg);
/*
* Get acceleration firmware flags.
*/
int atomisp_acc_get_state(struct atomisp_sub_device *asd,
struct atomisp_acc_state *arg);
#endif /* __ATOMISP_ACC_H__ */
......@@ -140,19 +140,6 @@ struct atomisp_calibration_group32 {
compat_uptr_t calb_grp_values;
};
struct atomisp_acc_fw_load32 {
unsigned int size;
unsigned int fw_handle;
compat_uptr_t data;
};
struct atomisp_acc_fw_arg32 {
unsigned int fw_handle;
unsigned int index;
compat_uptr_t value;
compat_size_t size;
};
struct v4l2_private_int_data32 {
__u32 size;
compat_uptr_t data;
......@@ -170,21 +157,6 @@ struct atomisp_shading_table32 {
compat_uptr_t data[ATOMISP_NUM_SC_COLORS];
};
struct atomisp_acc_map32 {
__u32 flags; /* Flags, see list below */
__u32 length; /* Length of data in bytes */
compat_uptr_t user_ptr; /* Pointer into user space */
compat_ulong_t css_ptr; /* Pointer into CSS address space */
__u32 reserved[4]; /* Set to zero */
};
struct atomisp_acc_s_mapped_arg32 {
unsigned int fw_handle;
__u32 memory; /* one of enum atomisp_acc_memory */
compat_size_t length;
compat_ulong_t css_ptr;
};
struct atomisp_parameters32 {
compat_uptr_t wb_config; /* White Balance config */
compat_uptr_t cc_config; /* Color Correction config */
......@@ -265,15 +237,6 @@ struct atomisp_parameters32 {
u32 per_frame_setting;
};
struct atomisp_acc_fw_load_to_pipe32 {
__u32 flags; /* Flags, see below for valid values */
unsigned int fw_handle; /* Handle, filled by kernel. */
__u32 size; /* Firmware binary size */
compat_uptr_t data; /* Pointer to firmware */
__u32 type; /* Binary type */
__u32 reserved[3]; /* Set to zero */
};
struct atomisp_dvs_6axis_config32 {
u32 exp_id;
u32 width_y;
......@@ -323,15 +286,6 @@ struct atomisp_sensor_ae_bracketing_lut32 {
#define ATOMISP_IOC_G_SENSOR_CALIBRATION_GROUP32 \
_IOWR('v', BASE_VIDIOC_PRIVATE + 22, struct atomisp_calibration_group32)
#define ATOMISP_IOC_ACC_LOAD32 \
_IOWR('v', BASE_VIDIOC_PRIVATE + 24, struct atomisp_acc_fw_load32)
#define ATOMISP_IOC_ACC_S_ARG32 \
_IOW('v', BASE_VIDIOC_PRIVATE + 24, struct atomisp_acc_fw_arg32)
#define ATOMISP_IOC_ACC_DESTAB32 \
_IOW('v', BASE_VIDIOC_PRIVATE + 25, struct atomisp_acc_fw_arg32)
#define ATOMISP_IOC_G_SENSOR_PRIV_INT_DATA32 \
_IOWR('v', BASE_VIDIOC_PRIVATE + 26, struct v4l2_private_int_data32)
......@@ -341,18 +295,6 @@ struct atomisp_sensor_ae_bracketing_lut32 {
#define ATOMISP_IOC_G_MOTOR_PRIV_INT_DATA32 \
_IOWR('v', BASE_VIDIOC_PRIVATE + 29, struct v4l2_private_int_data32)
#define ATOMISP_IOC_ACC_MAP32 \
_IOWR('v', BASE_VIDIOC_PRIVATE + 30, struct atomisp_acc_map32)
#define ATOMISP_IOC_ACC_UNMAP32 \
_IOW('v', BASE_VIDIOC_PRIVATE + 30, struct atomisp_acc_map32)
#define ATOMISP_IOC_ACC_S_MAPPED_ARG32 \
_IOW('v', BASE_VIDIOC_PRIVATE + 30, struct atomisp_acc_s_mapped_arg32)
#define ATOMISP_IOC_ACC_LOAD_TO_PIPE32 \
_IOWR('v', BASE_VIDIOC_PRIVATE + 31, struct atomisp_acc_fw_load_to_pipe32)
#define ATOMISP_IOC_S_PARAMETERS32 \
_IOW('v', BASE_VIDIOC_PRIVATE + 32, struct atomisp_parameters32)
......
......@@ -3118,38 +3118,6 @@ static long atomisp_vidioc_default(struct file *file, void *fh,
err = -EINVAL;
break;
case ATOMISP_IOC_ACC_LOAD:
err = atomisp_acc_load(asd, arg);
break;
case ATOMISP_IOC_ACC_LOAD_TO_PIPE:
err = atomisp_acc_load_to_pipe(asd, arg);
break;
case ATOMISP_IOC_ACC_UNLOAD:
err = atomisp_acc_unload(asd, arg);
break;
case ATOMISP_IOC_ACC_START:
err = atomisp_acc_start(asd, arg);
break;
case ATOMISP_IOC_ACC_WAIT:
err = atomisp_acc_wait(asd, arg);
break;
case ATOMISP_IOC_ACC_MAP:
err = atomisp_acc_map(asd, arg);
break;
case ATOMISP_IOC_ACC_UNMAP:
err = atomisp_acc_unmap(asd, arg);
break;
case ATOMISP_IOC_ACC_S_MAPPED_ARG:
err = atomisp_acc_s_mapped_arg(asd, arg);
break;
case ATOMISP_IOC_S_ISP_SHD_TAB:
err = atomisp_set_shading_table(asd, arg);
break;
......@@ -3198,12 +3166,6 @@ static long atomisp_vidioc_default(struct file *file, void *fh,
case ATOMISP_IOC_S_EXPOSURE_WINDOW:
err = atomisp_s_ae_window(asd, arg);
break;
case ATOMISP_IOC_S_ACC_STATE:
err = atomisp_acc_set_state(asd, arg);
break;
case ATOMISP_IOC_G_ACC_STATE:
err = atomisp_acc_get_state(asd, arg);
break;
case ATOMISP_IOC_INJECT_A_FAKE_EVENT:
err = atomisp_inject_a_fake_event(asd, arg);
break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment