Commit e2fa7b36 authored by Michael Grzeschik's avatar Michael Grzeschik Committed by Greg Kroah-Hartman

usb: gadget: uvc: move structs to common header

The functions and structs of the configfs interface should also be used
by the uvc gadget driver. This patch prepares the stack by moving the
common structs and functions to the common header file.
Reviewed-by: default avatarPaul Elder <paul.elder@ideasonboard.com>
Reviewed-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarMichael Grzeschik <m.grzeschik@pengutronix.de>

Link: https://lore.kernel.org/r/20220421211427.3400834-5-m.grzeschik@pengutronix.deSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent a350cfb6
...@@ -24,7 +24,6 @@ ...@@ -24,7 +24,6 @@
#include <media/v4l2-dev.h> #include <media/v4l2-dev.h>
#include <media/v4l2-event.h> #include <media/v4l2-event.h>
#include "u_uvc.h"
#include "uvc.h" #include "uvc.h"
#include "uvc_configfs.h" #include "uvc_configfs.h"
#include "uvc_v4l2.h" #include "uvc_v4l2.h"
......
...@@ -10,17 +10,14 @@ ...@@ -10,17 +10,14 @@
* Author: Andrzej Pietrasiewicz <andrzejtp2010@gmail.com> * Author: Andrzej Pietrasiewicz <andrzejtp2010@gmail.com>
*/ */
#include <linux/sort.h>
#include "u_uvc.h"
#include "uvc_configfs.h" #include "uvc_configfs.h"
#include <linux/sort.h>
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
* Global Utility Structures and Macros * Global Utility Structures and Macros
*/ */
#define UVCG_STREAMING_CONTROL_SIZE 1
#define UVC_ATTR(prefix, cname, aname) \ #define UVC_ATTR(prefix, cname, aname) \
static struct configfs_attribute prefix##attr_##cname = { \ static struct configfs_attribute prefix##attr_##cname = { \
.ca_name = __stringify(aname), \ .ca_name = __stringify(aname), \
...@@ -49,12 +46,6 @@ static int uvcg_config_compare_u32(const void *l, const void *r) ...@@ -49,12 +46,6 @@ static int uvcg_config_compare_u32(const void *l, const void *r)
return li < ri ? -1 : li == ri ? 0 : 1; return li < ri ? -1 : li == ri ? 0 : 1;
} }
static inline struct f_uvc_opts *to_f_uvc_opts(struct config_item *item)
{
return container_of(to_config_group(item), struct f_uvc_opts,
func_inst.group);
}
struct uvcg_config_group_type { struct uvcg_config_group_type {
struct config_item_type type; struct config_item_type type;
const char *name; const char *name;
...@@ -125,19 +116,6 @@ static void uvcg_config_remove_children(struct config_group *group) ...@@ -125,19 +116,6 @@ static void uvcg_config_remove_children(struct config_group *group)
* control/header * control/header
*/ */
DECLARE_UVC_HEADER_DESCRIPTOR(1);
struct uvcg_control_header {
struct config_item item;
struct UVC_HEADER_DESCRIPTOR(1) desc;
unsigned linked;
};
static struct uvcg_control_header *to_uvcg_control_header(struct config_item *item)
{
return container_of(item, struct uvcg_control_header, item);
}
#define UVCG_CTRL_HDR_ATTR(cname, aname, bits, limit) \ #define UVCG_CTRL_HDR_ATTR(cname, aname, bits, limit) \
static ssize_t uvcg_control_header_##cname##_show( \ static ssize_t uvcg_control_header_##cname##_show( \
struct config_item *item, char *page) \ struct config_item *item, char *page) \
...@@ -769,24 +747,6 @@ static const char * const uvcg_format_names[] = { ...@@ -769,24 +747,6 @@ static const char * const uvcg_format_names[] = {
"mjpeg", "mjpeg",
}; };
enum uvcg_format_type {
UVCG_UNCOMPRESSED = 0,
UVCG_MJPEG,
};
struct uvcg_format {
struct config_group group;
enum uvcg_format_type type;
unsigned linked;
unsigned num_frames;
__u8 bmaControls[UVCG_STREAMING_CONTROL_SIZE];
};
static struct uvcg_format *to_uvcg_format(struct config_item *item)
{
return container_of(to_config_group(item), struct uvcg_format, group);
}
static ssize_t uvcg_format_bma_controls_show(struct uvcg_format *f, char *page) static ssize_t uvcg_format_bma_controls_show(struct uvcg_format *f, char *page)
{ {
struct f_uvc_opts *opts; struct f_uvc_opts *opts;
...@@ -845,29 +805,11 @@ static ssize_t uvcg_format_bma_controls_store(struct uvcg_format *ch, ...@@ -845,29 +805,11 @@ static ssize_t uvcg_format_bma_controls_store(struct uvcg_format *ch,
return ret; return ret;
} }
struct uvcg_format_ptr {
struct uvcg_format *fmt;
struct list_head entry;
};
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
* streaming/header/<NAME> * streaming/header/<NAME>
* streaming/header * streaming/header
*/ */
struct uvcg_streaming_header {
struct config_item item;
struct uvc_input_header_descriptor desc;
unsigned linked;
struct list_head formats;
unsigned num_fmt;
};
static struct uvcg_streaming_header *to_uvcg_streaming_header(struct config_item *item)
{
return container_of(item, struct uvcg_streaming_header, item);
}
static void uvcg_format_set_indices(struct config_group *fmt); static void uvcg_format_set_indices(struct config_group *fmt);
static int uvcg_streaming_header_allow_link(struct config_item *src, static int uvcg_streaming_header_allow_link(struct config_item *src,
...@@ -1059,31 +1001,6 @@ static const struct uvcg_config_group_type uvcg_streaming_header_grp_type = { ...@@ -1059,31 +1001,6 @@ static const struct uvcg_config_group_type uvcg_streaming_header_grp_type = {
* streaming/<mode>/<format>/<NAME> * streaming/<mode>/<format>/<NAME>
*/ */
struct uvcg_frame {
struct config_item item;
enum uvcg_format_type fmt_type;
struct {
u8 b_length;
u8 b_descriptor_type;
u8 b_descriptor_subtype;
u8 b_frame_index;
u8 bm_capabilities;
u16 w_width;
u16 w_height;
u32 dw_min_bit_rate;
u32 dw_max_bit_rate;
u32 dw_max_video_frame_buffer_size;
u32 dw_default_frame_interval;
u8 b_frame_interval_type;
} __attribute__((packed)) frame;
u32 *dw_frame_interval;
};
static struct uvcg_frame *to_uvcg_frame(struct config_item *item)
{
return container_of(item, struct uvcg_frame, item);
}
#define UVCG_FRAME_ATTR(cname, aname, bits) \ #define UVCG_FRAME_ATTR(cname, aname, bits) \
static ssize_t uvcg_frame_##cname##_show(struct config_item *item, char *page)\ static ssize_t uvcg_frame_##cname##_show(struct config_item *item, char *page)\
{ \ { \
...@@ -1420,18 +1337,6 @@ static void uvcg_format_set_indices(struct config_group *fmt) ...@@ -1420,18 +1337,6 @@ static void uvcg_format_set_indices(struct config_group *fmt)
* streaming/uncompressed/<NAME> * streaming/uncompressed/<NAME>
*/ */
struct uvcg_uncompressed {
struct uvcg_format fmt;
struct uvc_format_uncompressed desc;
};
static struct uvcg_uncompressed *to_uvcg_uncompressed(struct config_item *item)
{
return container_of(
container_of(to_config_group(item), struct uvcg_format, group),
struct uvcg_uncompressed, fmt);
}
static struct configfs_group_operations uvcg_uncompressed_group_ops = { static struct configfs_group_operations uvcg_uncompressed_group_ops = {
.make_item = uvcg_frame_make, .make_item = uvcg_frame_make,
.drop_item = uvcg_frame_drop, .drop_item = uvcg_frame_drop,
...@@ -1675,18 +1580,6 @@ static const struct uvcg_config_group_type uvcg_uncompressed_grp_type = { ...@@ -1675,18 +1580,6 @@ static const struct uvcg_config_group_type uvcg_uncompressed_grp_type = {
* streaming/mjpeg/<NAME> * streaming/mjpeg/<NAME>
*/ */
struct uvcg_mjpeg {
struct uvcg_format fmt;
struct uvc_format_mjpeg desc;
};
static struct uvcg_mjpeg *to_uvcg_mjpeg(struct config_item *item)
{
return container_of(
container_of(to_config_group(item), struct uvcg_format, group),
struct uvcg_mjpeg, fmt);
}
static struct configfs_group_operations uvcg_mjpeg_group_ops = { static struct configfs_group_operations uvcg_mjpeg_group_ops = {
.make_item = uvcg_frame_make, .make_item = uvcg_frame_make,
.drop_item = uvcg_frame_drop, .drop_item = uvcg_frame_drop,
......
...@@ -12,7 +12,119 @@ ...@@ -12,7 +12,119 @@
#ifndef UVC_CONFIGFS_H #ifndef UVC_CONFIGFS_H
#define UVC_CONFIGFS_H #define UVC_CONFIGFS_H
struct f_uvc_opts; #include <linux/configfs.h>
#include "u_uvc.h"
static inline struct f_uvc_opts *to_f_uvc_opts(struct config_item *item)
{
return container_of(to_config_group(item), struct f_uvc_opts,
func_inst.group);
}
#define UVCG_STREAMING_CONTROL_SIZE 1
DECLARE_UVC_HEADER_DESCRIPTOR(1);
struct uvcg_control_header {
struct config_item item;
struct UVC_HEADER_DESCRIPTOR(1) desc;
unsigned linked;
};
static inline struct uvcg_control_header *to_uvcg_control_header(struct config_item *item)
{
return container_of(item, struct uvcg_control_header, item);
}
enum uvcg_format_type {
UVCG_UNCOMPRESSED = 0,
UVCG_MJPEG,
};
struct uvcg_format {
struct config_group group;
enum uvcg_format_type type;
unsigned linked;
unsigned num_frames;
__u8 bmaControls[UVCG_STREAMING_CONTROL_SIZE];
};
struct uvcg_format_ptr {
struct uvcg_format *fmt;
struct list_head entry;
};
static inline struct uvcg_format *to_uvcg_format(struct config_item *item)
{
return container_of(to_config_group(item), struct uvcg_format, group);
}
struct uvcg_streaming_header {
struct config_item item;
struct uvc_input_header_descriptor desc;
unsigned linked;
struct list_head formats;
unsigned num_fmt;
};
static inline struct uvcg_streaming_header *to_uvcg_streaming_header(struct config_item *item)
{
return container_of(item, struct uvcg_streaming_header, item);
}
struct uvcg_frame {
struct config_item item;
enum uvcg_format_type fmt_type;
struct {
u8 b_length;
u8 b_descriptor_type;
u8 b_descriptor_subtype;
u8 b_frame_index;
u8 bm_capabilities;
u16 w_width;
u16 w_height;
u32 dw_min_bit_rate;
u32 dw_max_bit_rate;
u32 dw_max_video_frame_buffer_size;
u32 dw_default_frame_interval;
u8 b_frame_interval_type;
} __attribute__((packed)) frame;
u32 *dw_frame_interval;
};
static inline struct uvcg_frame *to_uvcg_frame(struct config_item *item)
{
return container_of(item, struct uvcg_frame, item);
}
/* -----------------------------------------------------------------------------
* streaming/uncompressed/<NAME>
*/
struct uvcg_uncompressed {
struct uvcg_format fmt;
struct uvc_format_uncompressed desc;
};
static inline struct uvcg_uncompressed *to_uvcg_uncompressed(struct config_item *item)
{
return container_of(to_uvcg_format(item), struct uvcg_uncompressed, fmt);
}
/* -----------------------------------------------------------------------------
* streaming/mjpeg/<NAME>
*/
struct uvcg_mjpeg {
struct uvcg_format fmt;
struct uvc_format_mjpeg desc;
};
static inline struct uvcg_mjpeg *to_uvcg_mjpeg(struct config_item *item)
{
return container_of(to_uvcg_format(item), struct uvcg_mjpeg, fmt);
}
int uvcg_attach_configfs(struct f_uvc_opts *opts); int uvcg_attach_configfs(struct f_uvc_opts *opts);
......
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