blob: b604768f4648602322cf1fbda6565bd712218fc5 [file] [log] [blame]
codeworkx5b604fa2012-11-11 11:38:03 +01001/*
2 * Copyright (C) 2011 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#include <errno.h>
17#include <string.h>
18
19#include <hardware/hardware.h>
20#include <hardware/nfc.h>
21
22static uint8_t pn544_eedata_settings[][4] = {
23 // DIFFERENTIAL_ANTENNA
24
25 // RF Settings
26 {0x00,0x9B,0xD1,0x0D} // Tx consumption higher than 0x0D (average 50mA)
27 ,{0x00,0x9B,0xD2,0x24} // GSP setting for this threshold
28 ,{0x00,0x9B,0xD3,0x0A} // Tx consumption higher than 0x0A (average 40mA)
29 ,{0x00,0x9B,0xD4,0x22} // GSP setting for this threshold
30 ,{0x00,0x9B,0xD5,0x08} // Tx consumption higher than 0x08 (average 30mA)
31 ,{0x00,0x9B,0xD6,0x1E} // GSP setting for this threshold
32 ,{0x00,0x9B,0xDD,0x1C} // GSP setting for this threshold
33 ,{0x00,0x9B,0x84,0x13} // ANACM2 setting
34 ,{0x00,0x99,0x81,0x7F} // ANAVMID setting PCD
35 ,{0x00,0x99,0x31,0x70} // ANAVMID setting PICC
36
37 // Enable PBTF
38 ,{0x00,0x98,0x00,0x3F} // SECURE_ELEMENT_CONFIGURATION - No Secure Element
39 ,{0x00,0x9F,0x09,0x00} // SWP_PBTF_RFU
40 ,{0x00,0x9F,0x0A,0x05} // SWP_PBTF_RFLD --> RFLEVEL Detector for PBTF
41 ,{0x00,0x9E,0xD1,0xA1} //
42
43 // Change RF Level Detector ANARFLDWU
44 ,{0x00,0x99,0x23,0x00} // Default Value is 0x01
45
46 // Low-power polling
47 ,{0x00,0x9E,0x74,0xB0} // Default Value is 0x00, bits 0->2: sensitivity (0==max, 6==min),
48 // bit 3: RFU,
49 // bits 4,5 hybrid low-power: # of low-power polls per regular poll
50 // bit 6: RFU
51 // bit 7: (0 -> disabled, 1 -> enabled)
52 ,{0x00,0x9E,0x7D,0xB0} // bits 0->3: RFU,
53 // bits 4,5: # retries after low power detection
54 // 0=1 retry, 1=2 retry, 2=3 retry, 3=4 retry
55 // bit 6: RFU,
56 // bit 7: Enable or disable retry mechanism (0: disable, 1: enable)
57 ,{0x00,0x9F,0x28,0x01} // bits 0->7: # of measurements per low-power poll
58
59 //LLC Timer
60 ,{0x00,0x9C,0x31,0x00} // Guard host time-out in ms (MSB)
61 ,{0x00,0x9C,0x32,0xC8} // Guard host time-out in ms (LSB)
62 ,{0x00,0x9C,0x19,0x40} // Max RX retry (PN544=>host?)
63 ,{0x00,0x9C,0x1A,0x40} // Max TX retry (PN544=>host?)
64
65 ,{0x00,0x9C,0x0C,0x00} //
66 ,{0x00,0x9C,0x0D,0x00} //
67 ,{0x00,0x9C,0x12,0x00} //
68 ,{0x00,0x9C,0x13,0x00} //
69
70 //WTX for LLCP communication
71 ,{0x00,0x98,0xA2,0x0E} // Max value: 14 (default value: 09)
72
73 //SE GPIO
74 ,{0x00, 0x98, 0x93, 0x40}
75
76 // Set NFCT ATQA
77 ,{0x00, 0x98, 0x7D, 0x02}
78 ,{0x00, 0x98, 0x7E, 0x00}
79
80 // Enable CEA detection mechanism
81 ,{0x00, 0x9F, 0xC8, 0x01}
82 // Set NFC-F poll RC=0x00
83 ,{0x00, 0x9F, 0x9A, 0x00}
84 // Setting for EMD support for ISO 14443-4 Reader
85 ,{0x00,0x9F,0x09,0x00} // 0x00 - Disable EMD support, 0x01 - Enable EMD support
86};
87
88static int pn544_close(hw_device_t *dev) {
89 free(dev);
90
91 return 0;
92}
93
94/*
95 * Generic device handling
96 */
97
98static int nfc_open(const hw_module_t* module, const char* name,
99 hw_device_t** device) {
100 if (strcmp(name, NFC_PN544_CONTROLLER) == 0) {
101 nfc_pn544_device_t *dev = calloc(1, sizeof(nfc_pn544_device_t));
102
103 dev->common.tag = HARDWARE_DEVICE_TAG;
104 dev->common.version = 0;
105 dev->common.module = (struct hw_module_t*) module;
106 dev->common.close = pn544_close;
107
108 dev->num_eeprom_settings = sizeof(pn544_eedata_settings) / 4;
109 dev->eeprom_settings = (uint8_t*)pn544_eedata_settings;
110 dev->linktype = PN544_LINK_TYPE_I2C;
111 dev->device_node = "/dev/pn544";
112 dev->enable_i2c_workaround = 1;
113 *device = (hw_device_t*) dev;
114 return 0;
115 } else {
116 return -EINVAL;
117 }
118}
119
120static struct hw_module_methods_t nfc_module_methods = {
121 .open = nfc_open,
122};
123
124struct nfc_module_t HAL_MODULE_INFO_SYM = {
125 .common = {
126 .tag = HARDWARE_MODULE_TAG,
127 .version_major = 1,
128 .version_minor = 0,
129 .id = NFC_HARDWARE_MODULE_ID,
130 .name = "Herring NFC HW HAL",
131 .author = "The Android Open Source Project",
132 .methods = &nfc_module_methods,
133 },
134};