Thomas Gleixner | c942fdd | 2019-05-27 08:55:06 +0200 | [diff] [blame^] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | /* ------------------------------------------------------------------------ * |
| 3 | * i2c-parport.h I2C bus over parallel port * |
| 4 | * ------------------------------------------------------------------------ * |
Jean Delvare | 7c81c60f | 2014-01-29 20:40:08 +0100 | [diff] [blame] | 5 | Copyright (C) 2003-2010 Jean Delvare <jdelvare@suse.de> |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 6 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 | * ------------------------------------------------------------------------ */ |
| 8 | |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 9 | #define PORT_DATA 0 |
| 10 | #define PORT_STAT 1 |
| 11 | #define PORT_CTRL 2 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 12 | |
| 13 | struct lineop { |
| 14 | u8 val; |
| 15 | u8 port; |
| 16 | u8 inverted; |
| 17 | }; |
| 18 | |
| 19 | struct adapter_parm { |
| 20 | struct lineop setsda; |
| 21 | struct lineop setscl; |
| 22 | struct lineop getsda; |
| 23 | struct lineop getscl; |
| 24 | struct lineop init; |
Jean Delvare | 3585925 | 2010-03-02 12:23:44 +0100 | [diff] [blame] | 25 | unsigned int smbus_alert:1; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 26 | }; |
| 27 | |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 28 | static const struct adapter_parm adapter_parm[] = { |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 29 | /* type 0: Philips adapter */ |
| 30 | { |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 31 | .setsda = { 0x80, PORT_DATA, 1 }, |
| 32 | .setscl = { 0x08, PORT_CTRL, 0 }, |
| 33 | .getsda = { 0x80, PORT_STAT, 0 }, |
| 34 | .getscl = { 0x08, PORT_STAT, 0 }, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 35 | }, |
| 36 | /* type 1: home brew teletext adapter */ |
| 37 | { |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 38 | .setsda = { 0x02, PORT_DATA, 0 }, |
| 39 | .setscl = { 0x01, PORT_DATA, 0 }, |
| 40 | .getsda = { 0x80, PORT_STAT, 1 }, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 41 | }, |
| 42 | /* type 2: Velleman K8000 adapter */ |
| 43 | { |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 44 | .setsda = { 0x02, PORT_CTRL, 1 }, |
| 45 | .setscl = { 0x08, PORT_CTRL, 1 }, |
| 46 | .getsda = { 0x10, PORT_STAT, 0 }, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 47 | }, |
| 48 | /* type 3: ELV adapter */ |
| 49 | { |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 50 | .setsda = { 0x02, PORT_DATA, 1 }, |
| 51 | .setscl = { 0x01, PORT_DATA, 1 }, |
| 52 | .getsda = { 0x40, PORT_STAT, 1 }, |
| 53 | .getscl = { 0x08, PORT_STAT, 1 }, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 54 | }, |
| 55 | /* type 4: ADM1032 evaluation board */ |
| 56 | { |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 57 | .setsda = { 0x02, PORT_DATA, 1 }, |
| 58 | .setscl = { 0x01, PORT_DATA, 1 }, |
| 59 | .getsda = { 0x10, PORT_STAT, 1 }, |
| 60 | .init = { 0xf0, PORT_DATA, 0 }, |
Jean Delvare | 3585925 | 2010-03-02 12:23:44 +0100 | [diff] [blame] | 61 | .smbus_alert = 1, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 62 | }, |
| 63 | /* type 5: ADM1025, ADM1030 and ADM1031 evaluation boards */ |
| 64 | { |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 65 | .setsda = { 0x02, PORT_DATA, 1 }, |
| 66 | .setscl = { 0x01, PORT_DATA, 1 }, |
| 67 | .getsda = { 0x10, PORT_STAT, 1 }, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 68 | }, |
Peter Korsgaard | 1d26f45 | 2005-11-26 20:18:43 +0100 | [diff] [blame] | 69 | /* type 6: Barco LPT->DVI (K5800236) adapter */ |
| 70 | { |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 71 | .setsda = { 0x02, PORT_DATA, 1 }, |
| 72 | .setscl = { 0x01, PORT_DATA, 1 }, |
| 73 | .getsda = { 0x20, PORT_STAT, 0 }, |
| 74 | .getscl = { 0x40, PORT_STAT, 0 }, |
| 75 | .init = { 0xfc, PORT_DATA, 0 }, |
Peter Korsgaard | 1d26f45 | 2005-11-26 20:18:43 +0100 | [diff] [blame] | 76 | }, |
Jonathan McDowell | 55249cf | 2007-02-13 22:09:02 +0100 | [diff] [blame] | 77 | /* type 7: One For All JP1 parallel port adapter */ |
| 78 | { |
Jean Delvare | 07da037 | 2011-05-24 20:58:49 +0200 | [diff] [blame] | 79 | .setsda = { 0x01, PORT_DATA, 0 }, |
| 80 | .setscl = { 0x02, PORT_DATA, 0 }, |
| 81 | .getsda = { 0x80, PORT_STAT, 1 }, |
| 82 | .init = { 0x04, PORT_DATA, 1 }, |
Jonathan McDowell | 55249cf | 2007-02-13 22:09:02 +0100 | [diff] [blame] | 83 | }, |
Ondrej Zary | 82cd5d0 | 2015-07-13 19:31:12 +0200 | [diff] [blame] | 84 | /* type 8: VCT-jig */ |
| 85 | { |
| 86 | .setsda = { 0x04, PORT_DATA, 1 }, |
| 87 | .setscl = { 0x01, PORT_DATA, 1 }, |
| 88 | .getsda = { 0x40, PORT_STAT, 0 }, |
| 89 | .getscl = { 0x80, PORT_STAT, 1 }, |
| 90 | }, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 91 | }; |
| 92 | |
Mark M. Hoffman | e97b81d | 2006-03-23 16:50:25 +0100 | [diff] [blame] | 93 | static int type = -1; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 94 | module_param(type, int, 0); |
| 95 | MODULE_PARM_DESC(type, |
| 96 | "Type of adapter:\n" |
| 97 | " 0 = Philips adapter\n" |
| 98 | " 1 = home brew teletext adapter\n" |
| 99 | " 2 = Velleman K8000 adapter\n" |
| 100 | " 3 = ELV adapter\n" |
| 101 | " 4 = ADM1032 evaluation board\n" |
Peter Korsgaard | 1d26f45 | 2005-11-26 20:18:43 +0100 | [diff] [blame] | 102 | " 5 = ADM1025, ADM1030 and ADM1031 evaluation boards\n" |
| 103 | " 6 = Barco LPT->DVI (K5800236) adapter\n" |
Jonathan McDowell | 55249cf | 2007-02-13 22:09:02 +0100 | [diff] [blame] | 104 | " 7 = One For All JP1 parallel port adapter\n" |
Ondrej Zary | 82cd5d0 | 2015-07-13 19:31:12 +0200 | [diff] [blame] | 105 | " 8 = VCT-jig\n" |
Peter Korsgaard | 1d26f45 | 2005-11-26 20:18:43 +0100 | [diff] [blame] | 106 | ); |