#define CPCAP_NR_IRQ_REG_BANKS 6
 #define CPCAP_NR_IRQ_CHIPS     3
+#define CPCAP_REGISTER_SIZE    4
+#define CPCAP_REGISTER_BITS    16
 
 struct cpcap_ddata {
        struct spi_device *spi;
        struct regmap *regmap;
 };
 
+static int cpcap_sense_irq(struct regmap *regmap, int irq)
+{
+       int regnum = irq / CPCAP_REGISTER_BITS;
+       int mask = BIT(irq % CPCAP_REGISTER_BITS);
+       int reg = CPCAP_REG_INTS1 + (regnum * CPCAP_REGISTER_SIZE);
+       int err, val;
+
+       if (reg < CPCAP_REG_INTS1 || reg > CPCAP_REG_INTS4)
+               return -EINVAL;
+
+       err = regmap_read(regmap, reg, &val);
+       if (err)
+               return err;
+
+       return !!(val & mask);
+}
+
+int cpcap_sense_virq(struct regmap *regmap, int virq)
+{
+       struct regmap_irq_chip_data *d = irq_get_chip_data(virq);
+       int irq_base = regmap_irq_chip_get_base(d);
+
+       return cpcap_sense_irq(regmap, virq - irq_base);
+}
+EXPORT_SYMBOL_GPL(cpcap_sense_virq);
+
 static int cpcap_check_revision(struct cpcap_ddata *cpcap)
 {
        u16 vendor, rev;