Lines Matching full:d
47 struct dvb_usb_device *d = input_get_drvdata(dev); in legacy_dvb_usb_getkeycode() local
48 struct rc_map_table *keymap = d->props.rc.legacy.rc_map_table; in legacy_dvb_usb_getkeycode()
49 unsigned int keymap_size = d->props.rc.legacy.rc_map_size; in legacy_dvb_usb_getkeycode()
70 struct dvb_usb_device *d = input_get_drvdata(dev); in legacy_dvb_usb_setkeycode() local
71 struct rc_map_table *keymap = d->props.rc.legacy.rc_map_table; in legacy_dvb_usb_setkeycode()
72 unsigned int keymap_size = d->props.rc.legacy.rc_map_size; in legacy_dvb_usb_setkeycode()
110 struct dvb_usb_device *d = in legacy_dvb_usb_read_remote_control() local
122 if (d->props.rc.legacy.rc_query(d,&event,&state)) { in legacy_dvb_usb_read_remote_control()
133 d->last_event = event; in legacy_dvb_usb_read_remote_control()
136 input_event(d->input_dev, EV_KEY, event, 1); in legacy_dvb_usb_read_remote_control()
137 input_sync(d->input_dev); in legacy_dvb_usb_read_remote_control()
138 input_event(d->input_dev, EV_KEY, d->last_event, 0); in legacy_dvb_usb_read_remote_control()
139 input_sync(d->input_dev); in legacy_dvb_usb_read_remote_control()
149 if (d->last_state != REMOTE_NO_KEY_PRESSED) { in legacy_dvb_usb_read_remote_control()
150 deb_rc("releasing event %d\n",d->last_event); in legacy_dvb_usb_read_remote_control()
151 input_event(d->rc_input_dev, EV_KEY, d->last_event, 0); in legacy_dvb_usb_read_remote_control()
152 input_sync(d->rc_input_dev); in legacy_dvb_usb_read_remote_control()
154 d->last_state = REMOTE_NO_KEY_PRESSED; in legacy_dvb_usb_read_remote_control()
155 d->last_event = 0; in legacy_dvb_usb_read_remote_control()
159 deb_rc("pressing event %d\n",event); in legacy_dvb_usb_read_remote_control()
161 input_event(d->rc_input_dev, EV_KEY, event, 1); in legacy_dvb_usb_read_remote_control()
162 input_sync(d->rc_input_dev); in legacy_dvb_usb_read_remote_control()
164 d->last_event = event; in legacy_dvb_usb_read_remote_control()
165 d->last_state = REMOTE_KEY_PRESSED; in legacy_dvb_usb_read_remote_control()
169 if (d->last_state != REMOTE_NO_KEY_PRESSED) { in legacy_dvb_usb_read_remote_control()
170 deb_rc("repeating event %d\n",d->last_event); in legacy_dvb_usb_read_remote_control()
171 input_event(d->rc_input_dev, EV_KEY, d->last_event, 2); in legacy_dvb_usb_read_remote_control()
172 input_sync(d->rc_input_dev); in legacy_dvb_usb_read_remote_control()
173 d->last_state = REMOTE_KEY_REPEAT; in legacy_dvb_usb_read_remote_control()
181 schedule_delayed_work(&d->rc_query_work,msecs_to_jiffies(d->props.rc.legacy.rc_interval)); in legacy_dvb_usb_read_remote_control()
184 static int legacy_dvb_usb_remote_init(struct dvb_usb_device *d) in legacy_dvb_usb_remote_init() argument
195 input_dev->phys = d->rc_phys; in legacy_dvb_usb_remote_init()
196 usb_to_input_id(d->udev, &input_dev->id); in legacy_dvb_usb_remote_init()
197 input_dev->dev.parent = &d->udev->dev; in legacy_dvb_usb_remote_init()
198 d->input_dev = input_dev; in legacy_dvb_usb_remote_init()
199 d->rc_dev = NULL; in legacy_dvb_usb_remote_init()
205 deb_rc("key map size: %d\n", d->props.rc.legacy.rc_map_size); in legacy_dvb_usb_remote_init()
206 for (i = 0; i < d->props.rc.legacy.rc_map_size; i++) { in legacy_dvb_usb_remote_init()
207 deb_rc("setting bit for event %d item %d\n", in legacy_dvb_usb_remote_init()
208 d->props.rc.legacy.rc_map_table[i].keycode, i); in legacy_dvb_usb_remote_init()
209 set_bit(d->props.rc.legacy.rc_map_table[i].keycode, input_dev->keybit); in legacy_dvb_usb_remote_init()
213 input_dev->rep[REP_PERIOD] = d->props.rc.legacy.rc_interval; in legacy_dvb_usb_remote_init()
214 input_dev->rep[REP_DELAY] = d->props.rc.legacy.rc_interval + 150; in legacy_dvb_usb_remote_init()
216 input_set_drvdata(input_dev, d); in legacy_dvb_usb_remote_init()
222 rc_interval = d->props.rc.legacy.rc_interval; in legacy_dvb_usb_remote_init()
224 INIT_DELAYED_WORK(&d->rc_query_work, legacy_dvb_usb_read_remote_control); in legacy_dvb_usb_remote_init()
226 info("schedule remote query interval to %d msecs.", rc_interval); in legacy_dvb_usb_remote_init()
227 schedule_delayed_work(&d->rc_query_work, in legacy_dvb_usb_remote_init()
230 d->state |= DVB_USB_STATE_REMOTE; in legacy_dvb_usb_remote_init()
242 struct dvb_usb_device *d = in dvb_usb_read_remote_control() local
252 if (dvb_usb_disable_rc_polling || d->props.rc.core.bulk_mode) in dvb_usb_read_remote_control()
255 err = d->props.rc.core.rc_query(d); in dvb_usb_read_remote_control()
257 err("error %d while querying for an remote control event.", err); in dvb_usb_read_remote_control()
259 schedule_delayed_work(&d->rc_query_work, in dvb_usb_read_remote_control()
260 msecs_to_jiffies(d->props.rc.core.rc_interval)); in dvb_usb_read_remote_control()
263 static int rc_core_dvb_usb_remote_init(struct dvb_usb_device *d) in rc_core_dvb_usb_remote_init() argument
272 dev->driver_name = d->props.rc.core.module_name; in rc_core_dvb_usb_remote_init()
273 dev->map_name = d->props.rc.core.rc_codes; in rc_core_dvb_usb_remote_init()
274 dev->change_protocol = d->props.rc.core.change_protocol; in rc_core_dvb_usb_remote_init()
275 dev->allowed_protos = d->props.rc.core.allowed_protos; in rc_core_dvb_usb_remote_init()
276 dev->driver_type = d->props.rc.core.driver_type; in rc_core_dvb_usb_remote_init()
277 usb_to_input_id(d->udev, &dev->input_id); in rc_core_dvb_usb_remote_init()
279 dev->input_phys = d->rc_phys; in rc_core_dvb_usb_remote_init()
280 dev->dev.parent = &d->udev->dev; in rc_core_dvb_usb_remote_init()
281 dev->priv = d; in rc_core_dvb_usb_remote_init()
289 d->input_dev = NULL; in rc_core_dvb_usb_remote_init()
290 d->rc_dev = dev; in rc_core_dvb_usb_remote_init()
292 if (!d->props.rc.core.rc_query || d->props.rc.core.bulk_mode) in rc_core_dvb_usb_remote_init()
296 INIT_DELAYED_WORK(&d->rc_query_work, dvb_usb_read_remote_control); in rc_core_dvb_usb_remote_init()
298 rc_interval = d->props.rc.core.rc_interval; in rc_core_dvb_usb_remote_init()
300 info("schedule remote query interval to %d msecs.", rc_interval); in rc_core_dvb_usb_remote_init()
301 schedule_delayed_work(&d->rc_query_work, in rc_core_dvb_usb_remote_init()
307 int dvb_usb_remote_init(struct dvb_usb_device *d) in dvb_usb_remote_init() argument
314 if (d->props.rc.legacy.rc_map_table && d->props.rc.legacy.rc_query) in dvb_usb_remote_init()
315 d->props.rc.mode = DVB_RC_LEGACY; in dvb_usb_remote_init()
316 else if (d->props.rc.core.rc_codes) in dvb_usb_remote_init()
317 d->props.rc.mode = DVB_RC_CORE; in dvb_usb_remote_init()
321 usb_make_path(d->udev, d->rc_phys, sizeof(d->rc_phys)); in dvb_usb_remote_init()
322 strlcat(d->rc_phys, "/ir0", sizeof(d->rc_phys)); in dvb_usb_remote_init()
325 if (d->props.rc.legacy.rc_interval < 40) in dvb_usb_remote_init()
326 d->props.rc.legacy.rc_interval = 100; /* default */ in dvb_usb_remote_init()
328 if (d->props.rc.mode == DVB_RC_LEGACY) in dvb_usb_remote_init()
329 err = legacy_dvb_usb_remote_init(d); in dvb_usb_remote_init()
331 err = rc_core_dvb_usb_remote_init(d); in dvb_usb_remote_init()
335 d->state |= DVB_USB_STATE_REMOTE; in dvb_usb_remote_init()
340 int dvb_usb_remote_exit(struct dvb_usb_device *d) in dvb_usb_remote_exit() argument
342 if (d->state & DVB_USB_STATE_REMOTE) { in dvb_usb_remote_exit()
343 cancel_delayed_work_sync(&d->rc_query_work); in dvb_usb_remote_exit()
344 if (d->props.rc.mode == DVB_RC_LEGACY) in dvb_usb_remote_exit()
345 input_unregister_device(d->input_dev); in dvb_usb_remote_exit()
347 rc_unregister_device(d->rc_dev); in dvb_usb_remote_exit()
349 d->state &= ~DVB_USB_STATE_REMOTE; in dvb_usb_remote_exit()
356 int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *d, in dvb_usb_nec_rc_key_to_event() argument
360 struct rc_map_table *keymap = d->props.rc.legacy.rc_map_table; in dvb_usb_nec_rc_key_to_event()
373 for (i = 0; i < d->props.rc.legacy.rc_map_size; i++) in dvb_usb_nec_rc_key_to_event()
386 deb_err("unknown type of remote status: %d\n",keybuf[0]); in dvb_usb_nec_rc_key_to_event()