DAI(MIXER1 TX3),
        DAI(MIXER1 TX4),
        DAI(MIXER1 TX5),
+       /* XBAR -> OPE -> XBAR */
+       DAI(OPE1 RX),
+       DAI(OPE1 TX),
+       DAI(OPE2 RX),
+       DAI(OPE2 TX),
 };
 
 static struct snd_soc_dai_driver tegra186_ahub_dais[] = {
        DAI(ASRC1 RX6),
        DAI(ASRC1 TX6),
        DAI(ASRC1 RX7),
+       /* XBAR -> OPE -> XBAR */
+       DAI(OPE1 RX),
+       DAI(OPE1 TX),
 };
 
 static const char * const tegra210_ahub_mux_texts[] = {
        "MIXER1 TX3",
        "MIXER1 TX4",
        "MIXER1 TX5",
+       "OPE1",
+       "OPE2",
 };
 
 static const char * const tegra186_ahub_mux_texts[] = {
        "ASRC1 TX4",
        "ASRC1 TX5",
        "ASRC1 TX6",
+       "OPE1",
 };
 
 static const unsigned int tegra210_ahub_mux_values[] = {
        MUX_VALUE(1, 2),
        MUX_VALUE(1, 3),
        MUX_VALUE(1, 4),
+       /* OPE */
+       MUX_VALUE(2, 0),
+       MUX_VALUE(2, 1),
 };
 
 static const unsigned int tegra186_ahub_mux_values[] = {
        MUX_VALUE(3, 27),
        MUX_VALUE(3, 28),
        MUX_VALUE(3, 29),
+       /* OPE */
+       MUX_VALUE(2, 0),
 };
 
 /* Controls for t210 */
 MUX_ENUM_CTRL_DECL(t210_mixer18_tx, 0x27);
 MUX_ENUM_CTRL_DECL(t210_mixer19_tx, 0x28);
 MUX_ENUM_CTRL_DECL(t210_mixer110_tx, 0x29);
+MUX_ENUM_CTRL_DECL(t210_ope1_tx, 0x40);
+MUX_ENUM_CTRL_DECL(t210_ope2_tx, 0x41);
 
 /* Controls for t186 */
 MUX_ENUM_CTRL_DECL_186(t186_admaif1_tx, 0x00);
 MUX_ENUM_CTRL_DECL_186(t186_asrc15_tx, 0x70);
 MUX_ENUM_CTRL_DECL_186(t186_asrc16_tx, 0x71);
 MUX_ENUM_CTRL_DECL_186(t186_asrc17_tx, 0x72);
+MUX_ENUM_CTRL_DECL_186(t186_ope1_tx, 0x40);
 
 /* Controls for t234 */
 MUX_ENUM_CTRL_DECL_234(t234_mvc1_tx, 0x44);
        TX_WIDGETS("MIXER1 TX3"),
        TX_WIDGETS("MIXER1 TX4"),
        TX_WIDGETS("MIXER1 TX5"),
+       WIDGETS("OPE1", t210_ope1_tx),
+       WIDGETS("OPE2", t210_ope2_tx),
 };
 
 static const struct snd_soc_dapm_widget tegra186_ahub_widgets[] = {
        TX_WIDGETS("ASRC1 TX4"),
        TX_WIDGETS("ASRC1 TX5"),
        TX_WIDGETS("ASRC1 TX6"),
+       WIDGETS("OPE1", t186_ope1_tx),
 };
 
 static const struct snd_soc_dapm_widget tegra234_ahub_widgets[] = {
        TX_WIDGETS("ASRC1 TX4"),
        TX_WIDGETS("ASRC1 TX5"),
        TX_WIDGETS("ASRC1 TX6"),
+       WIDGETS("OPE1", t186_ope1_tx),
 };
 
 #define TEGRA_COMMON_MUX_ROUTES(name)                                  \
        { name " Mux",          "MIXER1 TX2",   "MIXER1 TX2 XBAR-RX" }, \
        { name " Mux",          "MIXER1 TX3",   "MIXER1 TX3 XBAR-RX" }, \
        { name " Mux",          "MIXER1 TX4",   "MIXER1 TX4 XBAR-RX" }, \
-       { name " Mux",          "MIXER1 TX5",   "MIXER1 TX5 XBAR-RX" },
+       { name " Mux",          "MIXER1 TX5",   "MIXER1 TX5 XBAR-RX" }, \
+       { name " Mux",          "OPE1",         "OPE1 XBAR-RX" },
+
+#define TEGRA210_ONLY_MUX_ROUTES(name)                                 \
+       { name " Mux",          "OPE2",         "OPE2 XBAR-RX" },
 
 #define TEGRA186_ONLY_MUX_ROUTES(name)                                 \
        { name " Mux",          "ADMAIF11",     "ADMAIF11 XBAR-RX" },   \
        { name " Mux",          "ASRC1 TX5",    "ASRC1 TX5 XBAR-RX" },  \
        { name " Mux",          "ASRC1 TX6",    "ASRC1 TX6 XBAR-RX" },
 
-#define TEGRA210_MUX_ROUTES(name)                                              \
-       TEGRA_COMMON_MUX_ROUTES(name)
+#define TEGRA210_MUX_ROUTES(name)                                      \
+       TEGRA_COMMON_MUX_ROUTES(name)                                   \
+       TEGRA210_ONLY_MUX_ROUTES(name)
 
-#define TEGRA186_MUX_ROUTES(name)                                              \
+#define TEGRA186_MUX_ROUTES(name)                                      \
        TEGRA_COMMON_MUX_ROUTES(name)                                   \
        TEGRA186_ONLY_MUX_ROUTES(name)
 
        TEGRA210_MUX_ROUTES("MIXER1 RX8")
        TEGRA210_MUX_ROUTES("MIXER1 RX9")
        TEGRA210_MUX_ROUTES("MIXER1 RX10")
+       TEGRA210_MUX_ROUTES("OPE1")
+       TEGRA210_MUX_ROUTES("OPE2")
 };
 
 static const struct snd_soc_dapm_route tegra186_ahub_routes[] = {
        TEGRA186_MUX_ROUTES("ASRC1 RX5")
        TEGRA186_MUX_ROUTES("ASRC1 RX6")
        TEGRA186_MUX_ROUTES("ASRC1 RX7")
+       TEGRA186_MUX_ROUTES("OPE1")
 };
 
 static const struct snd_soc_component_driver tegra210_ahub_component = {