skt->stat[i].desc = gpio_to_desc(skt->stat[i].gpio);
                }
 
-               if (skt->stat[i].desc) {
+               if (i < SOC_STAT_VS1 && skt->stat[i].desc) {
                        int irq = gpiod_to_irq(skt->stat[i].desc);
 
                        if (irq > 0) {
                state.bvd1 = !!gpiod_get_value(skt->stat[SOC_STAT_BVD1].desc);
        if (skt->stat[SOC_STAT_BVD2].desc)
                state.bvd2 = !!gpiod_get_value(skt->stat[SOC_STAT_BVD2].desc);
+       if (skt->stat[SOC_STAT_VS1].desc)
+               state.vs_3v = !!gpiod_get_value(skt->stat[SOC_STAT_VS1].desc);
+       if (skt->stat[SOC_STAT_VS2].desc)
+               state.vs_Xv = !!gpiod_get_value(skt->stat[SOC_STAT_VS2].desc);
 
        skt->ops->socket_state(skt, &state);
 
 
                struct gpio_desc *desc;
                unsigned int    irq;
                const char      *name;
-       } stat[4];
+       } stat[6];
 #define SOC_STAT_CD            0       /* Card detect */
 #define SOC_STAT_BVD1          1       /* BATDEAD / IOSTSCHG */
 #define SOC_STAT_BVD2          2       /* BATWARN / IOSPKR */
 #define SOC_STAT_RDY           3       /* Ready / Interrupt */
+#define SOC_STAT_VS1           4       /* Voltage sense 1 */
+#define SOC_STAT_VS2           5       /* Voltage sense 2 */
 
        struct gpio_desc        *gpio_reset;
        struct gpio_desc        *gpio_bus_enable;