{
struct qos_info *qos = &dev->qos;
+ /* Power up and set dongle to 9600 baud */
+ sirdev_set_dtr_rts(dev, FALSE, TRUE);
+
qos->baud_rate.bits &= IR_9600|IR_19200|IR_115200;
qos->min_turn_time.bits = 0x01; /* Needs at least 10 ms */
irda_qos_bits_to_value(qos);
- /* shouldn't we do set_dtr_rts(FALSE, TRUE) here (power up at 9600)? */
+ /* irda thread waits 50 msec for power settling */
return 0;
}
static int esi_close(struct sir_dev *dev)
{
/* Power off dongle */
- dev->set_dtr_rts(dev, FALSE, FALSE);
+ sirdev_set_dtr_rts(dev, FALSE, FALSE);
return 0;
}
/*
* Function esi_change_speed (task)
*
- * Set the speed for the Extended Systems JetEye PC ESI-9680 type dongle
+ * Set the speed for the Extended Systems JetEye PC ESI-9680 type dongle
+ * Apparently (see old esi-driver) no delays are needed here...
*
*/
static int esi_change_speed(struct sir_dev *dev, unsigned speed)
{
+ int ret = 0;
int dtr, rts;
switch (speed) {
dtr = rts = TRUE;
break;
default:
+ ret = -EINVAL;
speed = 9600;
/* fall through */
case 9600:
}
/* Change speed of dongle */
- dev->set_dtr_rts(dev, dtr, rts);
+ sirdev_set_dtr_rts(dev, dtr, rts);
dev->speed = speed;
- /* do we need some delay for power stabilization? */
-
- return 0;
+ return ret;
}
/*
*/
static int esi_reset(struct sir_dev *dev)
{
- dev->set_dtr_rts(dev, FALSE, FALSE);
-
- /* Hm, probably repower to 9600 and some delays? */
+ sirdev_set_dtr_rts(dev, FALSE, FALSE);
+
+ /* Hm, the old esi-driver left the dongle unpowered relying on
+ * the following speed change to repower. This might work for
+ * the esi because we only need the modem lines. However, now the
+ * general rule is reset must bring the dongle to some working
+ * well-known state because speed change might write to registers.
+ * The old esi-driver didn't any delay here - let's hope it' fine.
+ */
+
+ sirdev_set_dtr_rts(dev, FALSE, TRUE);
+ dev->speed = 9600;
return 0;
}