soundwire: Remove cdns_master_ops
authorShreyas NC <shreyas.nc@intel.com>
Thu, 26 Apr 2018 13:08:43 +0000 (18:38 +0530)
committerVinod Koul <vkoul@kernel.org>
Fri, 11 May 2018 16:18:05 +0000 (21:48 +0530)
There can be instances where drivers using Cadence IP might want
to set sdw_master_ops differently per instance of it's use, so
remove the cdns_master_ops and export the APIs.

Signed-off-by: Shreyas NC <shreyas.nc@intel.com>
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/soundwire/cadence_master.c
drivers/soundwire/cadence_master.h
drivers/soundwire/intel.c

index 3a9b1462039b77f4eca238160a68762a7c7a34f8..b0c09efd8f8302b43bd6e0e94cef2e48019bdcbc 100644 (file)
@@ -396,7 +396,7 @@ static int cdns_prep_msg(struct sdw_cdns *cdns, struct sdw_msg *msg, int *cmd)
        return 0;
 }
 
-static enum sdw_command_response
+enum sdw_command_response
 cdns_xfer_msg(struct sdw_bus *bus, struct sdw_msg *msg)
 {
        struct sdw_cdns *cdns = bus_to_cdns(bus);
@@ -422,8 +422,9 @@ cdns_xfer_msg(struct sdw_bus *bus, struct sdw_msg *msg)
 exit:
        return ret;
 }
+EXPORT_SYMBOL(cdns_xfer_msg);
 
-static enum sdw_command_response
+enum sdw_command_response
 cdns_xfer_msg_defer(struct sdw_bus *bus,
                struct sdw_msg *msg, struct sdw_defer *defer)
 {
@@ -443,8 +444,9 @@ cdns_xfer_msg_defer(struct sdw_bus *bus,
 
        return _cdns_xfer_msg(cdns, msg, cmd, 0, msg->len, true);
 }
+EXPORT_SYMBOL(cdns_xfer_msg_defer);
 
-static enum sdw_command_response
+enum sdw_command_response
 cdns_reset_page_addr(struct sdw_bus *bus, unsigned int dev_num)
 {
        struct sdw_cdns *cdns = bus_to_cdns(bus);
@@ -456,6 +458,7 @@ cdns_reset_page_addr(struct sdw_bus *bus, unsigned int dev_num)
 
        return cdns_program_scp_addr(cdns, &msg);
 }
+EXPORT_SYMBOL(cdns_reset_page_addr);
 
 /*
  * IRQ handling
@@ -727,14 +730,6 @@ int sdw_cdns_init(struct sdw_cdns *cdns)
 }
 EXPORT_SYMBOL(sdw_cdns_init);
 
-struct sdw_master_ops sdw_cdns_master_ops = {
-       .read_prop = sdw_master_read_prop,
-       .xfer_msg = cdns_xfer_msg,
-       .xfer_msg_defer = cdns_xfer_msg_defer,
-       .reset_page_addr = cdns_reset_page_addr,
-};
-EXPORT_SYMBOL(sdw_cdns_master_ops);
-
 /**
  * sdw_cdns_probe() - Cadence probe routine
  * @cdns: Cadence instance
index beaf6c9804eb9269b366765ffea9bcf16e48d9c2..3ec74fa5f4f9364246ab62cd3e98e71434801f56 100644 (file)
@@ -44,5 +44,13 @@ irqreturn_t sdw_cdns_thread(int irq, void *dev_id);
 int sdw_cdns_init(struct sdw_cdns *cdns);
 int sdw_cdns_enable_interrupt(struct sdw_cdns *cdns);
 
+enum sdw_command_response
+cdns_xfer_msg(struct sdw_bus *bus, struct sdw_msg *msg);
 
+enum sdw_command_response
+cdns_xfer_msg_defer(struct sdw_bus *bus,
+               struct sdw_msg *msg, struct sdw_defer *defer);
+
+enum sdw_command_response
+cdns_reset_page_addr(struct sdw_bus *bus, unsigned int dev_num);
 #endif /* __SDW_CADENCE_H */
index 86a7bd1fc91280f802b4d2984829bffd4653f708..aa0c60133de5047841511667f132ba36c87300e0 100644 (file)
@@ -252,6 +252,13 @@ static int intel_prop_read(struct sdw_bus *bus)
        return 0;
 }
 
+static struct sdw_master_ops sdw_intel_ops = {
+       .read_prop = sdw_master_read_prop,
+       .xfer_msg = cdns_xfer_msg,
+       .xfer_msg_defer = cdns_xfer_msg_defer,
+       .reset_page_addr = cdns_reset_page_addr,
+};
+
 /*
  * probe and init
  */
@@ -276,8 +283,8 @@ static int intel_probe(struct platform_device *pdev)
        sdw_cdns_probe(&sdw->cdns);
 
        /* Set property read ops */
-       sdw_cdns_master_ops.read_prop = intel_prop_read;
-       sdw->cdns.bus.ops = &sdw_cdns_master_ops;
+       sdw_intel_ops.read_prop = intel_prop_read;
+       sdw->cdns.bus.ops = &sdw_intel_ops;
 
        platform_set_drvdata(pdev, sdw);