97 lines
2.1 KiB
C
97 lines
2.1 KiB
C
|
/*
|
||
|
* drivers/gpu/tegra/tegra_ion.c
|
||
|
*
|
||
|
* Copyright (C) 2011 Google, Inc.
|
||
|
*
|
||
|
* This software is licensed under the terms of the GNU General Public
|
||
|
* License version 2, as published by the Free Software Foundation, and
|
||
|
* may be copied, distributed, and modified under those terms.
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#include <linux/err.h>
|
||
|
#include <linux/ion.h>
|
||
|
#include <linux/platform_device.h>
|
||
|
#include <linux/slab.h>
|
||
|
#include "../ion_priv.h"
|
||
|
|
||
|
struct ion_device *idev;
|
||
|
struct ion_mapper *tegra_user_mapper;
|
||
|
int num_heaps;
|
||
|
struct ion_heap **heaps;
|
||
|
|
||
|
int tegra_ion_probe(struct platform_device *pdev)
|
||
|
{
|
||
|
struct ion_platform_data *pdata = pdev->dev.platform_data;
|
||
|
int err;
|
||
|
int i;
|
||
|
|
||
|
num_heaps = pdata->nr;
|
||
|
|
||
|
heaps = kzalloc(sizeof(struct ion_heap *) * pdata->nr, GFP_KERNEL);
|
||
|
|
||
|
idev = ion_device_create(NULL);
|
||
|
if (IS_ERR_OR_NULL(idev)) {
|
||
|
kfree(heaps);
|
||
|
return PTR_ERR(idev);
|
||
|
}
|
||
|
|
||
|
/* create the heaps as specified in the board file */
|
||
|
for (i = 0; i < num_heaps; i++) {
|
||
|
struct ion_platform_heap *heap_data = &pdata->heaps[i];
|
||
|
|
||
|
heaps[i] = ion_heap_create(heap_data);
|
||
|
if (IS_ERR_OR_NULL(heaps[i])) {
|
||
|
err = PTR_ERR(heaps[i]);
|
||
|
goto err;
|
||
|
}
|
||
|
ion_device_add_heap(idev, heaps[i]);
|
||
|
}
|
||
|
platform_set_drvdata(pdev, idev);
|
||
|
return 0;
|
||
|
err:
|
||
|
for (i = 0; i < num_heaps; i++) {
|
||
|
if (heaps[i])
|
||
|
ion_heap_destroy(heaps[i]);
|
||
|
}
|
||
|
kfree(heaps);
|
||
|
return err;
|
||
|
}
|
||
|
|
||
|
int tegra_ion_remove(struct platform_device *pdev)
|
||
|
{
|
||
|
struct ion_device *idev = platform_get_drvdata(pdev);
|
||
|
int i;
|
||
|
|
||
|
ion_device_destroy(idev);
|
||
|
for (i = 0; i < num_heaps; i++)
|
||
|
ion_heap_destroy(heaps[i]);
|
||
|
kfree(heaps);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static struct platform_driver ion_driver = {
|
||
|
.probe = tegra_ion_probe,
|
||
|
.remove = tegra_ion_remove,
|
||
|
.driver = { .name = "ion-tegra" }
|
||
|
};
|
||
|
|
||
|
static int __init ion_init(void)
|
||
|
{
|
||
|
return platform_driver_register(&ion_driver);
|
||
|
}
|
||
|
|
||
|
static void __exit ion_exit(void)
|
||
|
{
|
||
|
platform_driver_unregister(&ion_driver);
|
||
|
}
|
||
|
|
||
|
module_init(ion_init);
|
||
|
module_exit(ion_exit);
|
||
|
|