Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 2 | #ifndef __LINUX_MAPLE_H |
| 3 | #define __LINUX_MAPLE_H |
| 4 | |
Adrian McMenamin | 1795cf4 | 2008-07-29 22:10:56 +0900 | [diff] [blame] | 5 | #include <mach/maple.h> |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 6 | |
Paul Gortmaker | 313162d | 2012-01-30 11:46:54 -0500 | [diff] [blame] | 7 | struct device; |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 8 | extern struct bus_type maple_bus_type; |
| 9 | |
| 10 | /* Maple Bus command and response codes */ |
| 11 | enum maple_code { |
Adrian McMenamin | b233b28 | 2009-02-27 16:07:32 +0900 | [diff] [blame] | 12 | MAPLE_RESPONSE_FILEERR = -5, |
| 13 | MAPLE_RESPONSE_AGAIN, /* retransmit */ |
| 14 | MAPLE_RESPONSE_BADCMD, |
| 15 | MAPLE_RESPONSE_BADFUNC, |
| 16 | MAPLE_RESPONSE_NONE, /* unit didn't respond*/ |
| 17 | MAPLE_COMMAND_DEVINFO = 1, |
| 18 | MAPLE_COMMAND_ALLINFO, |
| 19 | MAPLE_COMMAND_RESET, |
| 20 | MAPLE_COMMAND_KILL, |
| 21 | MAPLE_RESPONSE_DEVINFO, |
| 22 | MAPLE_RESPONSE_ALLINFO, |
| 23 | MAPLE_RESPONSE_OK, |
| 24 | MAPLE_RESPONSE_DATATRF, |
| 25 | MAPLE_COMMAND_GETCOND, |
| 26 | MAPLE_COMMAND_GETMINFO, |
| 27 | MAPLE_COMMAND_BREAD, |
| 28 | MAPLE_COMMAND_BWRITE, |
| 29 | MAPLE_COMMAND_BSYNC, |
| 30 | MAPLE_COMMAND_SETCOND, |
| 31 | MAPLE_COMMAND_MICCONTROL |
| 32 | }; |
| 33 | |
| 34 | enum maple_file_errors { |
| 35 | MAPLE_FILEERR_INVALID_PARTITION = 0x01000000, |
| 36 | MAPLE_FILEERR_PHASE_ERROR = 0x02000000, |
| 37 | MAPLE_FILEERR_INVALID_BLOCK = 0x04000000, |
| 38 | MAPLE_FILEERR_WRITE_ERROR = 0x08000000, |
| 39 | MAPLE_FILEERR_INVALID_WRITE_LENGTH = 0x10000000, |
| 40 | MAPLE_FILEERR_BAD_CRC = 0x20000000 |
| 41 | }; |
| 42 | |
| 43 | struct maple_buffer { |
| 44 | char bufx[0x400]; |
| 45 | void *buf; |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 46 | }; |
| 47 | |
| 48 | struct mapleq { |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 49 | struct list_head list; |
| 50 | struct maple_device *dev; |
Adrian McMenamin | b233b28 | 2009-02-27 16:07:32 +0900 | [diff] [blame] | 51 | struct maple_buffer *recvbuf; |
| 52 | void *sendbuf, *recvbuf_p2; |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 53 | unsigned char length; |
| 54 | enum maple_code command; |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 55 | }; |
| 56 | |
| 57 | struct maple_devinfo { |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 58 | unsigned long function; |
| 59 | unsigned long function_data[3]; |
| 60 | unsigned char area_code; |
Paul Mundt | 5c8f82c | 2008-02-13 19:44:53 +0900 | [diff] [blame] | 61 | unsigned char connector_direction; |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 62 | char product_name[31]; |
| 63 | char product_licence[61]; |
| 64 | unsigned short standby_power; |
| 65 | unsigned short max_power; |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 66 | }; |
| 67 | |
| 68 | struct maple_device { |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 69 | struct maple_driver *driver; |
| 70 | struct mapleq *mq; |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 71 | void (*callback) (struct mapleq * mq); |
Adrian McMenamin | b233b28 | 2009-02-27 16:07:32 +0900 | [diff] [blame] | 72 | void (*fileerr_handler)(struct maple_device *mdev, void *recvbuf); |
| 73 | int (*can_unload)(struct maple_device *mdev); |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 74 | unsigned long when, interval, function; |
| 75 | struct maple_devinfo devinfo; |
| 76 | unsigned char port, unit; |
| 77 | char product_name[32]; |
| 78 | char product_licence[64]; |
Adrian McMenamin | b233b28 | 2009-02-27 16:07:32 +0900 | [diff] [blame] | 79 | atomic_t busy; |
| 80 | wait_queue_head_t maple_wait; |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 81 | struct device dev; |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 82 | }; |
| 83 | |
| 84 | struct maple_driver { |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 85 | unsigned long function; |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 86 | struct device_driver drv; |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 87 | }; |
| 88 | |
| 89 | void maple_getcond_callback(struct maple_device *dev, |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 90 | void (*callback) (struct mapleq * mq), |
| 91 | unsigned long interval, |
| 92 | unsigned long function); |
Paul Mundt | 6387029 | 2008-08-04 10:39:46 +0900 | [diff] [blame] | 93 | int maple_driver_register(struct maple_driver *); |
| 94 | void maple_driver_unregister(struct maple_driver *); |
| 95 | |
Adrian McMenamin | b233b28 | 2009-02-27 16:07:32 +0900 | [diff] [blame] | 96 | int maple_add_packet(struct maple_device *mdev, u32 function, |
Adrian McMenamin | 1795cf4 | 2008-07-29 22:10:56 +0900 | [diff] [blame] | 97 | u32 command, u32 length, void *data); |
| 98 | void maple_clear_dev(struct maple_device *mdev); |
Adrian McMenamin | 17be2d2 | 2007-09-21 15:55:55 +0900 | [diff] [blame] | 99 | |
| 100 | #define to_maple_dev(n) container_of(n, struct maple_device, dev) |
| 101 | #define to_maple_driver(n) container_of(n, struct maple_driver, drv) |
| 102 | |
Paul Mundt | 6178706 | 2008-08-04 10:58:24 +0900 | [diff] [blame] | 103 | #define maple_get_drvdata(d) dev_get_drvdata(&(d)->dev) |
| 104 | #define maple_set_drvdata(d,p) dev_set_drvdata(&(d)->dev, (p)) |
| 105 | |
Adrian McMenamin | b948237 | 2008-02-06 22:46:21 +0000 | [diff] [blame] | 106 | #endif /* __LINUX_MAPLE_H */ |