2018-05-08 21:20:54 +07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2015-12-04 00:21:29 +07:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Etnaviv Project
|
|
|
|
*/
|
2018-05-08 21:20:54 +07:00
|
|
|
|
2015-12-04 00:21:29 +07:00
|
|
|
#ifndef ETNAVIV_DUMP_H
|
|
|
|
#define ETNAVIV_DUMP_H
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
|
|
|
enum {
|
|
|
|
ETDUMP_MAGIC = 0x414e5445,
|
|
|
|
ETDUMP_BUF_REG = 0,
|
|
|
|
ETDUMP_BUF_MMU,
|
|
|
|
ETDUMP_BUF_RING,
|
|
|
|
ETDUMP_BUF_CMD,
|
|
|
|
ETDUMP_BUF_BOMAP,
|
|
|
|
ETDUMP_BUF_BO,
|
|
|
|
ETDUMP_BUF_END,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct etnaviv_dump_object_header {
|
|
|
|
__le32 magic;
|
|
|
|
__le32 type;
|
|
|
|
__le32 file_offset;
|
|
|
|
__le32 file_size;
|
|
|
|
__le64 iova;
|
|
|
|
__le32 data[2];
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Registers object, an array of these */
|
|
|
|
struct etnaviv_dump_registers {
|
|
|
|
__le32 reg;
|
|
|
|
__le32 value;
|
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
struct etnaviv_gpu;
|
|
|
|
void etnaviv_core_dump(struct etnaviv_gpu *gpu);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|