|
9 | 9 |
|
10 | 10 | #include <linux/module.h> |
11 | 11 | #include <linux/dma-mapping.h> |
| 12 | +#include <linux/of_address.h> |
12 | 13 | #include <linux/of_device.h> |
13 | 14 |
|
14 | 15 | #include <drm/drm_aperture.h> |
@@ -339,10 +340,45 @@ static int apple_probe_per_dcp(struct device *dev, |
339 | 340 | return drm_connector_attach_encoder(&connector->base, encoder); |
340 | 341 | } |
341 | 342 |
|
| 343 | +static int apple_get_fb_resource(struct device *dev, const char *name, |
| 344 | + struct resource *fb_r) |
| 345 | +{ |
| 346 | + int idx, ret = -ENODEV; |
| 347 | + struct device_node *node; |
| 348 | + |
| 349 | + idx = of_property_match_string(dev->of_node, "memory-region-names", name); |
| 350 | + |
| 351 | + node = of_parse_phandle(dev->of_node, "memory-region", idx); |
| 352 | + if (!node) { |
| 353 | + dev_err(dev, "reserved-memory node '%s' not found\n", name); |
| 354 | + return -ENODEV; |
| 355 | + } |
| 356 | + |
| 357 | + if (!of_device_is_available(node)) { |
| 358 | + dev_err(dev, "reserved-memory node '%s' is unavailable\n", name); |
| 359 | + goto err; |
| 360 | + } |
| 361 | + |
| 362 | + if (!of_device_is_compatible(node, "framebuffer")) { |
| 363 | + dev_err(dev, "reserved-memory node '%s' is incompatible\n", |
| 364 | + node->full_name); |
| 365 | + goto err; |
| 366 | + } |
| 367 | + |
| 368 | + ret = of_address_to_resource(node, 0, fb_r); |
| 369 | + |
| 370 | +err: |
| 371 | + of_node_put(node); |
| 372 | + return ret; |
| 373 | +} |
| 374 | + |
| 375 | + |
342 | 376 | static int apple_platform_probe(struct platform_device *pdev) |
343 | 377 | { |
344 | 378 | struct device *dev = &pdev->dev; |
345 | 379 | struct apple_drm_private *apple; |
| 380 | + struct resource fb_r; |
| 381 | + resource_size_t fb_size; |
346 | 382 | struct platform_device *dcp[MAX_COPROCESSORS]; |
347 | 383 | int ret, nr_dcp, i; |
348 | 384 |
|
@@ -380,6 +416,18 @@ static int apple_platform_probe(struct platform_device *pdev) |
380 | 416 | if (ret) |
381 | 417 | return ret; |
382 | 418 |
|
| 419 | + ret = apple_get_fb_resource(dev, "framebuffer", &fb_r); |
| 420 | + if (ret) |
| 421 | + return ret; |
| 422 | + |
| 423 | + fb_size = fb_r.end - fb_r.start + 1; |
| 424 | + ret = drm_aperture_remove_conflicting_framebuffers(fb_r.start, fb_size, |
| 425 | + false, &apple_drm_driver); |
| 426 | + if (ret) { |
| 427 | + dev_err(dev, "Failed remove fb: %d\n", ret); |
| 428 | + return ret; |
| 429 | + } |
| 430 | + |
383 | 431 | apple = devm_drm_dev_alloc(dev, &apple_drm_driver, |
384 | 432 | struct apple_drm_private, drm); |
385 | 433 | if (IS_ERR(apple)) |
@@ -425,11 +473,6 @@ static int apple_platform_probe(struct platform_device *pdev) |
425 | 473 |
|
426 | 474 | drm_mode_config_reset(&apple->drm); |
427 | 475 |
|
428 | | - // remove before registering our DRM device |
429 | | - ret = drm_aperture_remove_framebuffers(false, &apple_drm_driver); |
430 | | - if (ret) |
431 | | - return ret; |
432 | | - |
433 | 476 | ret = drm_dev_register(&apple->drm, 0); |
434 | 477 | if (ret) |
435 | 478 | goto err_unload; |
|
0 commit comments