2019-05-29 01:10:04 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2013-03-22 22:34:03 +08:00
|
|
|
/*
|
|
|
|
* Tegra host1x Channel
|
|
|
|
*
|
|
|
|
* Copyright (c) 2010-2013, NVIDIA Corporation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __HOST1X_CHANNEL_H
|
|
|
|
#define __HOST1X_CHANNEL_H
|
|
|
|
|
|
|
|
#include <linux/io.h>
|
2017-06-15 07:18:42 +08:00
|
|
|
#include <linux/kref.h>
|
2013-03-22 22:34:03 +08:00
|
|
|
|
|
|
|
#include "cdma.h"
|
|
|
|
|
|
|
|
struct host1x;
|
2017-06-15 07:18:42 +08:00
|
|
|
struct host1x_channel;
|
2013-03-22 22:34:03 +08:00
|
|
|
|
2017-06-15 07:18:42 +08:00
|
|
|
struct host1x_channel_list {
|
|
|
|
struct host1x_channel *channels;
|
|
|
|
unsigned long *allocated_channels;
|
|
|
|
};
|
2013-03-22 22:34:03 +08:00
|
|
|
|
2017-06-15 07:18:42 +08:00
|
|
|
struct host1x_channel {
|
|
|
|
struct kref refcount;
|
2013-03-22 22:34:03 +08:00
|
|
|
unsigned int id;
|
|
|
|
struct mutex submitlock;
|
|
|
|
void __iomem *regs;
|
2018-06-18 20:01:51 +08:00
|
|
|
struct host1x_client *client;
|
2013-03-22 22:34:03 +08:00
|
|
|
struct device *dev;
|
|
|
|
struct host1x_cdma cdma;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* channel list operations */
|
2017-06-15 07:18:42 +08:00
|
|
|
int host1x_channel_list_init(struct host1x_channel_list *chlist,
|
|
|
|
unsigned int num_channels);
|
|
|
|
void host1x_channel_list_free(struct host1x_channel_list *chlist);
|
|
|
|
struct host1x_channel *host1x_channel_get_index(struct host1x *host,
|
|
|
|
unsigned int index);
|
2013-03-22 22:34:03 +08:00
|
|
|
|
|
|
|
#endif
|