bool need_reset;        /* flag to issue a device resume cmd */
        u8 emver;               /* emulator interface version */
+       u8 num_txports;         /* number of transmit ports */
+       u8 num_rxports;         /* number of receive sensors */
+       u8 txports_cabled;      /* bitmask of transmitters with cable */
+       u8 rxports_active;      /* bitmask of active receive sensors */
 };
 
 /* MCE Device Command Strings, generally a port and command pair */
 static char GET_UNKNOWN2[]     = {MCE_CMD_PORT_IR, MCE_CMD_UNKNOWN2};
 static char GET_CARRIER_FREQ[] = {MCE_CMD_PORT_IR, MCE_CMD_GETIRCFS};
 static char GET_RX_TIMEOUT[]   = {MCE_CMD_PORT_IR, MCE_CMD_GETIRTIMEOUT};
+static char GET_NUM_PORTS[]    = {MCE_CMD_PORT_IR, MCE_CMD_GETIRNUMPORTS};
 static char GET_TX_BITMASK[]   = {MCE_CMD_PORT_IR, MCE_CMD_GETIRTXPORTS};
 static char GET_RX_SENSOR[]    = {MCE_CMD_PORT_IR, MCE_CMD_GETIRRXPORTEN};
 /* sub in desired values in lower byte or bytes for full command */
 
        switch (cmd) {
        case MCE_CMD_NULL:
+               if (subcmd == MCE_CMD_NULL)
+                       break;
                if ((subcmd == MCE_CMD_PORT_SYS) &&
                    (data1 == MCE_CMD_RESUME))
                        dev_info(dev, "Device resume requested\n");
        u8 lo = ir->buf_in[index + 2] & 0xff;
 
        switch (ir->buf_in[index]) {
+       /* the one and only 5-byte return value command */
+       case MCE_RSP_GETPORTSTATUS:
+               if ((ir->buf_in[index + 4] & 0xff) == 0x00)
+                       ir->txports_cabled |= 1 << hi;
+               break;
+
        /* 2-byte return value commands */
        case MCE_RSP_EQIRTIMEOUT:
                ir->rc->timeout = US_TO_NS((hi << 8 | lo) * MCE_TIME_UNIT);
                break;
+       case MCE_RSP_EQIRNUMPORTS:
+               ir->num_txports = hi;
+               ir->num_rxports = lo;
+               break;
 
        /* 1-byte return value commands */
        case MCE_RSP_EQEMVER:
                break;
        case MCE_RSP_EQIRRXPORTEN:
                ir->learning_enabled = ((hi & 0x02) == 0x02);
+               ir->rxports_active = hi;
                break;
        case MCE_RSP_CMD_ILLEGAL:
                ir->need_reset = true;
 
 static void mceusb_get_parameters(struct mceusb_dev *ir)
 {
+       int i;
+       unsigned char cmdbuf[3] = { MCE_CMD_PORT_SYS,
+                                   MCE_CMD_GETPORTSTATUS, 0x00 };
+
+       /* defaults, if the hardware doesn't support querying */
+       ir->num_txports = 2;
+       ir->num_rxports = 2;
+
+       /* get number of tx and rx ports */
+       mce_async_out(ir, GET_NUM_PORTS, sizeof(GET_NUM_PORTS));
+
        /* get the carrier and frequency */
        mce_async_out(ir, GET_CARRIER_FREQ, sizeof(GET_CARRIER_FREQ));
 
-       if (!ir->flags.no_tx)
+       if (ir->num_txports && !ir->flags.no_tx)
                /* get the transmitter bitmask */
                mce_async_out(ir, GET_TX_BITMASK, sizeof(GET_TX_BITMASK));
 
 
        /* get receiver sensor setting */
        mce_async_out(ir, GET_RX_SENSOR, sizeof(GET_RX_SENSOR));
+
+       for (i = 0; i < ir->num_txports; i++) {
+               cmdbuf[2] = i;
+               mce_async_out(ir, cmdbuf, sizeof(cmdbuf));
+       }
 }
 
 static struct rc_dev *mceusb_init_rc_dev(struct mceusb_dev *ir)
 
        dev_info(&intf->dev, "Registered %s with mce emulator interface "
                 "version %x\n", name, ir->emver);
+       dev_info(&intf->dev, "%x tx ports (0x%x cabled) and "
+                "%x rx sensors (0x%x active)\n",
+                ir->num_txports, ir->txports_cabled,
+                ir->num_rxports, ir->rxports_active);
 
        return 0;