const struct komeda_dev_funcs *
 d71_identify(u32 __iomem *reg_base, struct komeda_chip_info *chip)
 {
+       const struct komeda_dev_funcs *funcs;
+       u32 product_id;
+
+       chip->core_id = malidp_read32(reg_base, GLB_CORE_ID);
+
+       product_id = MALIDP_CORE_ID_PRODUCT_ID(chip->core_id);
+
+       switch (product_id) {
+       case MALIDP_D71_PRODUCT_ID:
+               funcs = &d71_chip_funcs;
+               break;
+       default:
+               DRM_ERROR("Unsupported product: 0x%x\n", product_id);
+               return NULL;
+       }
+
        chip->arch_id   = malidp_read32(reg_base, GLB_ARCH_ID);
-       chip->core_id   = malidp_read32(reg_base, GLB_CORE_ID);
        chip->core_info = malidp_read32(reg_base, GLB_CORE_INFO);
        chip->bus_width = D71_BUS_WIDTH_16_BYTES;
 
-       return &d71_chip_funcs;
+       return funcs;
 }
 
        .attrs = komeda_sysfs_entries,
 };
 
-static int komeda_parse_pipe_dt(struct komeda_dev *mdev, struct device_node *np)
+static int komeda_parse_pipe_dt(struct komeda_pipeline *pipe)
 {
-       struct komeda_pipeline *pipe;
+       struct device_node *np = pipe->of_node;
        struct clk *clk;
-       u32 pipe_id;
-       int ret = 0;
-
-       ret = of_property_read_u32(np, "reg", &pipe_id);
-       if (ret != 0 || pipe_id >= mdev->n_pipelines)
-               return -EINVAL;
-
-       pipe = mdev->pipelines[pipe_id];
 
        clk = of_clk_get_by_name(np, "pxclk");
        if (IS_ERR(clk)) {
-               DRM_ERROR("get pxclk for pipeline %d failed!\n", pipe_id);
+               DRM_ERROR("get pxclk for pipeline %d failed!\n", pipe->id);
                return PTR_ERR(clk);
        }
        pipe->pxlclk = clk;
                of_graph_get_port_by_id(np, KOMEDA_OF_PORT_OUTPUT);
 
        pipe->dual_link = pipe->of_output_links[0] && pipe->of_output_links[1];
-       pipe->of_node = of_node_get(np);
 
        return 0;
 }
 {
        struct platform_device *pdev = to_platform_device(dev);
        struct device_node *child, *np = dev->of_node;
-       int ret;
+       struct komeda_pipeline *pipe;
+       u32 pipe_id = U32_MAX;
+       int ret = -1;
 
        mdev->irq  = platform_get_irq(pdev, 0);
        if (mdev->irq < 0) {
        ret = 0;
 
        for_each_available_child_of_node(np, child) {
-               if (of_node_cmp(child->name, "pipeline") == 0) {
-                       ret = komeda_parse_pipe_dt(mdev, child);
-                       if (ret) {
-                               DRM_ERROR("parse pipeline dt error!\n");
-                               of_node_put(child);
-                               break;
+               if (of_node_name_eq(child, "pipeline")) {
+                       of_property_read_u32(child, "reg", &pipe_id);
+                       if (pipe_id >= mdev->n_pipelines) {
+                               DRM_WARN("Skip the redundant DT node: pipeline-%u.\n",
+                                        pipe_id);
+                               continue;
                        }
+                       mdev->pipelines[pipe_id]->of_node = of_node_get(child);
                }
        }
 
-       return ret;
+       for (pipe_id = 0; pipe_id < mdev->n_pipelines; pipe_id++) {
+               pipe = mdev->pipelines[pipe_id];
+
+               if (!pipe->of_node) {
+                       DRM_ERROR("Pipeline-%d doesn't have a DT node.\n",
+                                 pipe->id);
+                       return -EINVAL;
+               }
+               ret = komeda_parse_pipe_dt(pipe);
+               if (ret)
+                       return ret;
+       }
+
+       return 0;
 }
 
 struct komeda_dev *komeda_dev_create(struct device *dev)
 {
        struct platform_device *pdev = to_platform_device(dev);
-       const struct komeda_product_data *product;
+       komeda_identify_func komeda_identify;
        struct komeda_dev *mdev;
        int err = 0;
 
-       product = of_device_get_match_data(dev);
-       if (!product)
+       komeda_identify = of_device_get_match_data(dev);
+       if (!komeda_identify)
                return ERR_PTR(-ENODEV);
 
        mdev = devm_kzalloc(dev, sizeof(*mdev), GFP_KERNEL);
 
        clk_prepare_enable(mdev->aclk);
 
-       mdev->funcs = product->identify(mdev->reg_base, &mdev->chip);
-       if (!komeda_product_match(mdev, product->product_id)) {
-               DRM_ERROR("DT configured %x mismatch with real HW %x.\n",
-                         product->product_id,
-                         MALIDP_CORE_ID_PRODUCT_ID(mdev->chip.core_id));
+       mdev->funcs = komeda_identify(mdev->reg_base, &mdev->chip);
+       if (!mdev->funcs) {
+               DRM_ERROR("Failed to identify the HW.\n");
                err = -ENODEV;
                goto disable_clk;
        }