}
 DEFINE_SHOW_ATTRIBUTE(intel_reg);
 
+static int intel_set_m_datamode(void *data, u64 value)
+{
+       struct sdw_intel *sdw = data;
+       struct sdw_bus *bus = &sdw->cdns.bus;
+
+       if (value > SDW_PORT_DATA_MODE_STATIC_1)
+               return -EINVAL;
+
+       /* Userspace changed the hardware state behind the kernel's back */
+       add_taint(TAINT_USER, LOCKDEP_STILL_OK);
+
+       bus->params.m_data_mode = value;
+
+       return 0;
+}
+DEFINE_DEBUGFS_ATTRIBUTE(intel_set_m_datamode_fops, NULL,
+                        intel_set_m_datamode, "%llu\n");
+
+static int intel_set_s_datamode(void *data, u64 value)
+{
+       struct sdw_intel *sdw = data;
+       struct sdw_bus *bus = &sdw->cdns.bus;
+
+       if (value > SDW_PORT_DATA_MODE_STATIC_1)
+               return -EINVAL;
+
+       /* Userspace changed the hardware state behind the kernel's back */
+       add_taint(TAINT_USER, LOCKDEP_STILL_OK);
+
+       bus->params.s_data_mode = value;
+
+       return 0;
+}
+DEFINE_DEBUGFS_ATTRIBUTE(intel_set_s_datamode_fops, NULL,
+                        intel_set_s_datamode, "%llu\n");
+
 static void intel_debugfs_init(struct sdw_intel *sdw)
 {
        struct dentry *root = sdw->cdns.bus.debugfs;
        debugfs_create_file("intel-registers", 0400, sdw->debugfs, sdw,
                            &intel_reg_fops);
 
+       debugfs_create_file("intel-m-datamode", 0200, sdw->debugfs, sdw,
+                           &intel_set_m_datamode_fops);
+
+       debugfs_create_file("intel-s-datamode", 0200, sdw->debugfs, sdw,
+                           &intel_set_s_datamode_fops);
+
        sdw_cdns_debugfs_init(&sdw->cdns, sdw->debugfs);
 }