Laurent Pinchart | 176fb0d | 2009-12-09 08:39:58 -0300 | [diff] [blame^] | 1 | /* |
| 2 | * Media device |
| 3 | * |
| 4 | * Copyright (C) 2010 Nokia Corporation |
| 5 | * |
| 6 | * Contacts: Laurent Pinchart <laurent.pinchart@ideasonboard.com> |
| 7 | * Sakari Ailus <sakari.ailus@iki.fi> |
| 8 | * |
| 9 | * This program is free software; you can redistribute it and/or modify |
| 10 | * it under the terms of the GNU General Public License version 2 as |
| 11 | * published by the Free Software Foundation. |
| 12 | * |
| 13 | * This program is distributed in the hope that it will be useful, |
| 14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 16 | * GNU General Public License for more details. |
| 17 | * |
| 18 | * You should have received a copy of the GNU General Public License |
| 19 | * along with this program; if not, write to the Free Software |
| 20 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| 21 | */ |
| 22 | |
| 23 | #ifndef _MEDIA_DEVICE_H |
| 24 | #define _MEDIA_DEVICE_H |
| 25 | |
| 26 | #include <linux/device.h> |
| 27 | #include <linux/list.h> |
| 28 | |
| 29 | #include <media/media-devnode.h> |
| 30 | |
| 31 | /** |
| 32 | * struct media_device - Media device |
| 33 | * @dev: Parent device |
| 34 | * @devnode: Media device node |
| 35 | * @model: Device model name |
| 36 | * @serial: Device serial number (optional) |
| 37 | * @bus_info: Unique and stable device location identifier |
| 38 | * @hw_revision: Hardware device revision |
| 39 | * @driver_version: Device driver version |
| 40 | * |
| 41 | * This structure represents an abstract high-level media device. It allows easy |
| 42 | * access to entities and provides basic media device-level support. The |
| 43 | * structure can be allocated directly or embedded in a larger structure. |
| 44 | * |
| 45 | * The parent @dev is a physical device. It must be set before registering the |
| 46 | * media device. |
| 47 | * |
| 48 | * @model is a descriptive model name exported through sysfs. It doesn't have to |
| 49 | * be unique. |
| 50 | */ |
| 51 | struct media_device { |
| 52 | /* dev->driver_data points to this struct. */ |
| 53 | struct device *dev; |
| 54 | struct media_devnode devnode; |
| 55 | |
| 56 | char model[32]; |
| 57 | char serial[40]; |
| 58 | char bus_info[32]; |
| 59 | u32 hw_revision; |
| 60 | u32 driver_version; |
| 61 | }; |
| 62 | |
| 63 | /* media_devnode to media_device */ |
| 64 | #define to_media_device(node) container_of(node, struct media_device, devnode) |
| 65 | |
| 66 | int __must_check media_device_register(struct media_device *mdev); |
| 67 | void media_device_unregister(struct media_device *mdev); |
| 68 | |
| 69 | #endif |