Commit 7e761857 authored by Ezequiel Garcia's avatar Ezequiel Garcia Committed by Mauro Carvalho Chehab

media: v4l2-async: Remove V4L2_ASYNC_MATCH_DEVNAME

The last user for this type of match was the soc-camera/sh_mobile_csi2
driver, which was removed in v4.9. If the support is ever needed,
it can always be restored.

[Sakari Ailus: Also drop DEVNAME from debug prints recently added.]
Signed-off-by: default avatarEzequiel Garcia <ezequiel@collabora.com>
Reviewed-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent ea12d248
...@@ -66,12 +66,6 @@ static bool match_i2c(struct v4l2_async_notifier *notifier, ...@@ -66,12 +66,6 @@ static bool match_i2c(struct v4l2_async_notifier *notifier,
#endif #endif
} }
static bool match_devname(struct v4l2_async_notifier *notifier,
struct v4l2_subdev *sd, struct v4l2_async_subdev *asd)
{
return !strcmp(asd->match.device_name, dev_name(sd->dev));
}
static bool match_fwnode(struct v4l2_async_notifier *notifier, static bool match_fwnode(struct v4l2_async_notifier *notifier,
struct v4l2_subdev *sd, struct v4l2_async_subdev *asd) struct v4l2_subdev *sd, struct v4l2_async_subdev *asd)
{ {
...@@ -164,9 +158,6 @@ v4l2_async_find_match(struct v4l2_async_notifier *notifier, ...@@ -164,9 +158,6 @@ v4l2_async_find_match(struct v4l2_async_notifier *notifier,
list_for_each_entry(asd, &notifier->waiting, list) { list_for_each_entry(asd, &notifier->waiting, list) {
/* bus_type has been verified valid before */ /* bus_type has been verified valid before */
switch (asd->match_type) { switch (asd->match_type) {
case V4L2_ASYNC_MATCH_DEVNAME:
match = match_devname;
break;
case V4L2_ASYNC_MATCH_I2C: case V4L2_ASYNC_MATCH_I2C:
match = match_i2c; match = match_i2c;
break; break;
...@@ -195,9 +186,6 @@ static bool asd_equal(struct v4l2_async_subdev *asd_x, ...@@ -195,9 +186,6 @@ static bool asd_equal(struct v4l2_async_subdev *asd_x,
return false; return false;
switch (asd_x->match_type) { switch (asd_x->match_type) {
case V4L2_ASYNC_MATCH_DEVNAME:
return strcmp(asd_x->match.device_name,
asd_y->match.device_name) == 0;
case V4L2_ASYNC_MATCH_I2C: case V4L2_ASYNC_MATCH_I2C:
return asd_x->match.i2c.adapter_id == return asd_x->match.i2c.adapter_id ==
asd_y->match.i2c.adapter_id && asd_y->match.i2c.adapter_id &&
...@@ -464,7 +452,6 @@ static int v4l2_async_notifier_asd_valid(struct v4l2_async_notifier *notifier, ...@@ -464,7 +452,6 @@ static int v4l2_async_notifier_asd_valid(struct v4l2_async_notifier *notifier,
return -EINVAL; return -EINVAL;
switch (asd->match_type) { switch (asd->match_type) {
case V4L2_ASYNC_MATCH_DEVNAME:
case V4L2_ASYNC_MATCH_I2C: case V4L2_ASYNC_MATCH_I2C:
case V4L2_ASYNC_MATCH_FWNODE: case V4L2_ASYNC_MATCH_FWNODE:
if (v4l2_async_notifier_has_async_subdev(notifier, asd, if (v4l2_async_notifier_has_async_subdev(notifier, asd,
...@@ -718,31 +705,6 @@ v4l2_async_notifier_add_i2c_subdev(struct v4l2_async_notifier *notifier, ...@@ -718,31 +705,6 @@ v4l2_async_notifier_add_i2c_subdev(struct v4l2_async_notifier *notifier,
} }
EXPORT_SYMBOL_GPL(v4l2_async_notifier_add_i2c_subdev); EXPORT_SYMBOL_GPL(v4l2_async_notifier_add_i2c_subdev);
struct v4l2_async_subdev *
v4l2_async_notifier_add_devname_subdev(struct v4l2_async_notifier *notifier,
const char *device_name,
unsigned int asd_struct_size)
{
struct v4l2_async_subdev *asd;
int ret;
asd = kzalloc(asd_struct_size, GFP_KERNEL);
if (!asd)
return ERR_PTR(-ENOMEM);
asd->match_type = V4L2_ASYNC_MATCH_DEVNAME;
asd->match.device_name = device_name;
ret = v4l2_async_notifier_add_subdev(notifier, asd);
if (ret) {
kfree(asd);
return ERR_PTR(ret);
}
return asd;
}
EXPORT_SYMBOL_GPL(v4l2_async_notifier_add_devname_subdev);
int v4l2_async_register_subdev(struct v4l2_subdev *sd) int v4l2_async_register_subdev(struct v4l2_subdev *sd)
{ {
struct v4l2_async_notifier *subdev_notifier; struct v4l2_async_notifier *subdev_notifier;
...@@ -841,9 +803,6 @@ static void print_waiting_subdev(struct seq_file *s, ...@@ -841,9 +803,6 @@ static void print_waiting_subdev(struct seq_file *s,
struct v4l2_async_subdev *asd) struct v4l2_async_subdev *asd)
{ {
switch (asd->match_type) { switch (asd->match_type) {
case V4L2_ASYNC_MATCH_DEVNAME:
seq_printf(s, " [devname] dev=%s\n", asd->match.device_name);
break;
case V4L2_ASYNC_MATCH_I2C: case V4L2_ASYNC_MATCH_I2C:
seq_printf(s, " [i2c] dev=%d-%04x\n", asd->match.i2c.adapter_id, seq_printf(s, " [i2c] dev=%d-%04x\n", asd->match.i2c.adapter_id,
asd->match.i2c.address); asd->match.i2c.address);
......
...@@ -22,7 +22,6 @@ struct v4l2_async_notifier; ...@@ -22,7 +22,6 @@ struct v4l2_async_notifier;
* enum v4l2_async_match_type - type of asynchronous subdevice logic to be used * enum v4l2_async_match_type - type of asynchronous subdevice logic to be used
* in order to identify a match * in order to identify a match
* *
* @V4L2_ASYNC_MATCH_DEVNAME: Match will use the device name
* @V4L2_ASYNC_MATCH_I2C: Match will check for I2C adapter ID and address * @V4L2_ASYNC_MATCH_I2C: Match will check for I2C adapter ID and address
* @V4L2_ASYNC_MATCH_FWNODE: Match will use firmware node * @V4L2_ASYNC_MATCH_FWNODE: Match will use firmware node
* *
...@@ -30,7 +29,6 @@ struct v4l2_async_notifier; ...@@ -30,7 +29,6 @@ struct v4l2_async_notifier;
* algorithm that will be used to match an asynchronous device. * algorithm that will be used to match an asynchronous device.
*/ */
enum v4l2_async_match_type { enum v4l2_async_match_type {
V4L2_ASYNC_MATCH_DEVNAME,
V4L2_ASYNC_MATCH_I2C, V4L2_ASYNC_MATCH_I2C,
V4L2_ASYNC_MATCH_FWNODE, V4L2_ASYNC_MATCH_FWNODE,
}; };
...@@ -43,9 +41,6 @@ enum v4l2_async_match_type { ...@@ -43,9 +41,6 @@ enum v4l2_async_match_type {
* @match.fwnode: * @match.fwnode:
* pointer to &struct fwnode_handle to be matched. * pointer to &struct fwnode_handle to be matched.
* Used if @match_type is %V4L2_ASYNC_MATCH_FWNODE. * Used if @match_type is %V4L2_ASYNC_MATCH_FWNODE.
* @match.device_name:
* string containing the device name to be matched.
* Used if @match_type is %V4L2_ASYNC_MATCH_DEVNAME.
* @match.i2c: embedded struct with I2C parameters to be matched. * @match.i2c: embedded struct with I2C parameters to be matched.
* Both @match.i2c.adapter_id and @match.i2c.address * Both @match.i2c.adapter_id and @match.i2c.address
* should be matched. * should be matched.
...@@ -69,7 +64,6 @@ struct v4l2_async_subdev { ...@@ -69,7 +64,6 @@ struct v4l2_async_subdev {
enum v4l2_async_match_type match_type; enum v4l2_async_match_type match_type;
union { union {
struct fwnode_handle *fwnode; struct fwnode_handle *fwnode;
const char *device_name;
struct { struct {
int adapter_id; int adapter_id;
unsigned short address; unsigned short address;
...@@ -218,25 +212,6 @@ v4l2_async_notifier_add_i2c_subdev(struct v4l2_async_notifier *notifier, ...@@ -218,25 +212,6 @@ v4l2_async_notifier_add_i2c_subdev(struct v4l2_async_notifier *notifier,
int adapter_id, unsigned short address, int adapter_id, unsigned short address,
unsigned int asd_struct_size); unsigned int asd_struct_size);
/**
* v4l2_async_notifier_add_devname_subdev - Allocate and add a device-name
* async subdev to the notifier's master asd_list.
*
* @notifier: pointer to &struct v4l2_async_notifier
* @device_name: device name string to be matched
* @asd_struct_size: size of the driver's async sub-device struct, including
* sizeof(struct v4l2_async_subdev). The &struct
* v4l2_async_subdev shall be the first member of
* the driver's async sub-device struct, i.e. both
* begin at the same memory address.
*
* Same as above but for device-name matched sub-devices.
*/
struct v4l2_async_subdev *
v4l2_async_notifier_add_devname_subdev(struct v4l2_async_notifier *notifier,
const char *device_name,
unsigned int asd_struct_size);
/** /**
* v4l2_async_notifier_register - registers a subdevice asynchronous notifier * v4l2_async_notifier_register - registers a subdevice asynchronous notifier
* *
......
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