Lines Matching full:d

48 	struct dvb_usb_device *d = input_get_drvdata(dev);
49 struct rc_map_table *keymap = d->props.rc.legacy.rc_map_table;
50 unsigned int keymap_size = d->props.rc.legacy.rc_map_size;
71 struct dvb_usb_device *d = input_get_drvdata(dev);
72 struct rc_map_table *keymap = d->props.rc.legacy.rc_map_table;
73 unsigned int keymap_size = d->props.rc.legacy.rc_map_size;
111 struct dvb_usb_device *d =
123 if (d->props.rc.legacy.rc_query(d,&event,&state)) {
134 d->last_event = event;
135 input_event(d->input_dev, EV_KEY, event, 1);
136 input_sync(d->input_dev);
137 input_event(d->input_dev, EV_KEY, d->last_event, 0);
138 input_sync(d->input_dev);
142 input_event(d->input_dev, EV_KEY, event, 1);
143 input_sync(d->input_dev);
144 input_event(d->input_dev, EV_KEY, d->last_event, 0);
145 input_sync(d->input_dev);
155 if (d->last_state != REMOTE_NO_KEY_PRESSED) {
156 deb_rc("releasing event %d\n",d->last_event);
157 input_event(d->rc_input_dev, EV_KEY, d->last_event, 0);
158 input_sync(d->rc_input_dev);
160 d->last_state = REMOTE_NO_KEY_PRESSED;
161 d->last_event = 0;
165 deb_rc("pressing event %d\n",event);
167 input_event(d->rc_input_dev, EV_KEY, event, 1);
168 input_sync(d->rc_input_dev);
170 d->last_event = event;
171 d->last_state = REMOTE_KEY_PRESSED;
175 if (d->last_state != REMOTE_NO_KEY_PRESSED) {
176 deb_rc("repeating event %d\n",d->last_event);
177 input_event(d->rc_input_dev, EV_KEY, d->last_event, 2);
178 input_sync(d->rc_input_dev);
179 d->last_state = REMOTE_KEY_REPEAT;
187 schedule_delayed_work(&d->rc_query_work,msecs_to_jiffies(d->props.rc.legacy.rc_interval));
190 static int legacy_dvb_usb_remote_init(struct dvb_usb_device *d)
201 input_dev->phys = d->rc_phys;
202 usb_to_input_id(d->udev, &input_dev->id);
203 input_dev->dev.parent = &d->udev->dev;
204 d->input_dev = input_dev;
205 d->rc_dev = NULL;
211 deb_rc("key map size: %d\n", d->props.rc.legacy.rc_map_size);
212 for (i = 0; i < d->props.rc.legacy.rc_map_size; i++) {
213 deb_rc("setting bit for event %d item %d\n",
214 d->props.rc.legacy.rc_map_table[i].keycode, i);
215 set_bit(d->props.rc.legacy.rc_map_table[i].keycode, input_dev->keybit);
219 input_dev->rep[REP_PERIOD] = d->props.rc.legacy.rc_interval;
220 input_dev->rep[REP_DELAY] = d->props.rc.legacy.rc_interval + 150;
222 input_set_drvdata(input_dev, d);
228 rc_interval = d->props.rc.legacy.rc_interval;
230 INIT_DELAYED_WORK(&d->rc_query_work, legacy_dvb_usb_read_remote_control);
232 info("schedule remote query interval to %d msecs.", rc_interval);
233 schedule_delayed_work(&d->rc_query_work,
236 d->state |= DVB_USB_STATE_REMOTE;
248 struct dvb_usb_device *d =
258 if (dvb_usb_disable_rc_polling || d->props.rc.core.bulk_mode)
261 err = d->props.rc.core.rc_query(d);
263 err("error %d while querying for an remote control event.", err);
265 schedule_delayed_work(&d->rc_query_work,
266 msecs_to_jiffies(d->props.rc.core.rc_interval));
269 static int rc_core_dvb_usb_remote_init(struct dvb_usb_device *d)
274 dev = rc_allocate_device(d->props.rc.core.driver_type);
278 dev->driver_name = d->props.rc.core.module_name;
279 dev->map_name = d->props.rc.core.rc_codes;
280 dev->change_protocol = d->props.rc.core.change_protocol;
281 dev->allowed_protocols = d->props.rc.core.allowed_protos;
282 usb_to_input_id(d->udev, &dev->input_id);
283 dev->device_name = d->desc->name;
284 dev->input_phys = d->rc_phys;
285 dev->dev.parent = &d->udev->dev;
286 dev->priv = d;
287 dev->scancode_mask = d->props.rc.core.scancode_mask;
295 d->input_dev = NULL;
296 d->rc_dev = dev;
298 if (!d->props.rc.core.rc_query || d->props.rc.core.bulk_mode)
302 INIT_DELAYED_WORK(&d->rc_query_work, dvb_usb_read_remote_control);
304 rc_interval = d->props.rc.core.rc_interval;
306 info("schedule remote query interval to %d msecs.", rc_interval);
307 schedule_delayed_work(&d->rc_query_work,
313 int dvb_usb_remote_init(struct dvb_usb_device *d)
320 if (d->props.rc.legacy.rc_map_table && d->props.rc.legacy.rc_query)
321 d->props.rc.mode = DVB_RC_LEGACY;
322 else if (d->props.rc.core.rc_codes)
323 d->props.rc.mode = DVB_RC_CORE;
327 usb_make_path(d->udev, d->rc_phys, sizeof(d->rc_phys));
328 strlcat(d->rc_phys, "/ir0", sizeof(d->rc_phys));
331 if (d->props.rc.legacy.rc_interval < 40)
332 d->props.rc.legacy.rc_interval = 100; /* default */
334 if (d->props.rc.mode == DVB_RC_LEGACY)
335 err = legacy_dvb_usb_remote_init(d);
337 err = rc_core_dvb_usb_remote_init(d);
341 d->state |= DVB_USB_STATE_REMOTE;
346 int dvb_usb_remote_exit(struct dvb_usb_device *d)
348 if (d->state & DVB_USB_STATE_REMOTE) {
349 cancel_delayed_work_sync(&d->rc_query_work);
350 if (d->props.rc.mode == DVB_RC_LEGACY)
351 input_unregister_device(d->input_dev);
353 rc_unregister_device(d->rc_dev);
355 d->state &= ~DVB_USB_STATE_REMOTE;
362 int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *d,
366 struct rc_map_table *keymap = d->props.rc.legacy.rc_map_table;
379 for (i = 0; i < d->props.rc.legacy.rc_map_size; i++)
392 deb_err("unknown type of remote status: %d\n",keybuf[0]);