head	1.2;
access;
symbols
	netbsd-11-0-RC4:1.1.1.9
	netbsd-11-0-RC3:1.1.1.9
	netbsd-11-0-RC2:1.1.1.9
	netbsd-11-0-RC1:1.1.1.9
	netbsd-11:1.1.1.9.0.4
	netbsd-11-base:1.1.1.9
	libdrm-2-4-124:1.1.1.9
	netbsd-10-1-RELEASE:1.1.1.9
	libdrm-2-4-122:1.1.1.9
	netbsd-9-4-RELEASE:1.1.1.4
	netbsd-10-0-RELEASE:1.1.1.9
	netbsd-10-0-RC6:1.1.1.9
	netbsd-10-0-RC5:1.1.1.9
	netbsd-10-0-RC4:1.1.1.9
	netbsd-10-0-RC3:1.1.1.9
	netbsd-10-0-RC2:1.1.1.9
	netbsd-10-0-RC1:1.1.1.9
	netbsd-10:1.1.1.9.0.2
	netbsd-10-base:1.1.1.9
	libdrm-2-4-114:1.1.1.9
	netbsd-9-3-RELEASE:1.1.1.4
	libdrm-2-4-112:1.1.1.8
	libdrm-2-4-109:1.1.1.7
	libdrm-2-4-107:1.1.1.7
	netbsd-9-2-RELEASE:1.1.1.4
	libdrm-2-4-105:1.1.1.6
	libdrm-2-4-102:1.1.1.5
	netbsd-9-1-RELEASE:1.1.1.4
	libdrm-2-4-100:1.1.1.4
	netbsd-9-0-RELEASE:1.1.1.4
	netbsd-9-0-RC2:1.1.1.4
	netbsd-9-0-RC1:1.1.1.4
	netbsd-9:1.1.1.4.0.2
	netbsd-9-base:1.1.1.4
	libdrm-2-4-99:1.1.1.4
	libdrm-2-4-97:1.1.1.3
	libdrm-2-4-96:1.1.1.2
	libdrm-2-4-91:1.1.1.1
	xorg:1.1.1;
locks; strict;
comment	@ * @;


1.2
date	2026.06.10.05.27.44;	author mrg;	state dead;
branches;
next	1.1;
commitid	OkSNQummCTEKcdJG;

1.1
date	2018.03.14.07.18.37;	author mrg;	state Exp;
branches
	1.1.1.1;
next	;
commitid	vKK7pL0psl9szouA;

1.1.1.1
date	2018.03.14.07.18.37;	author mrg;	state Exp;
branches;
next	1.1.1.2;
commitid	vKK7pL0psl9szouA;

1.1.1.2
date	2019.01.10.08.49.54;	author mrg;	state Exp;
branches;
next	1.1.1.3;
commitid	XNB5UWAmSCOUmd7B;

1.1.1.3
date	2019.03.04.08.20.59;	author mrg;	state Exp;
branches;
next	1.1.1.4;
commitid	8yixCTrntx4nv1eB;

1.1.1.4
date	2019.07.15.05.42.03;	author mrg;	state Exp;
branches;
next	1.1.1.5;
commitid	fTEuGipA3XuNl6vB;

1.1.1.5
date	2020.11.01.09.51.26;	author mrg;	state Exp;
branches;
next	1.1.1.6;
commitid	af86gKDNccMIsauC;

1.1.1.6
date	2021.04.27.03.01.49;	author mrg;	state Exp;
branches;
next	1.1.1.7;
commitid	bnhxFHsntjvsvSQC;

1.1.1.7
date	2021.07.11.00.27.20;	author mrg;	state Exp;
branches;
next	1.1.1.8;
commitid	ssF6uXIaLv20fv0D;

1.1.1.8
date	2022.07.11.19.19.23;	author mrg;	state Exp;
branches;
next	1.1.1.9;
commitid	wjQfX0qND1IWLvLD;

1.1.1.9
date	2022.11.12.02.04.42;	author mrg;	state Exp;
branches;
next	;
commitid	fMjFZZt1HqTR3m1E;


desc
@@


1.2
log
@merge libdrm 2.4.134
@
text
@/*
 * Copyright 2017 Advanced Micro Devices, Inc.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 * OTHER DEALINGS IN THE SOFTWARE.
 *
*/

#ifdef HAVE_CONFIG_H
#include "config.h"
#endif

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#ifdef HAVE_ALLOCA_H
# include <alloca.h>
#endif

#include "CUnit/Basic.h"

#include "amdgpu_test.h"
#include "amdgpu_drm.h"
#include "amdgpu_internal.h"

#include <pthread.h>


/*
 * This defines the delay in MS after which memory location designated for
 * compression against reference value is written to, unblocking command
 * processor
 */
#define WRITE_MEM_ADDRESS_DELAY_MS 100

#define	PACKET_TYPE3	3

#define PACKET3(op, n)	((PACKET_TYPE3 << 30) |				\
			 (((op) & 0xFF) << 8) |				\
			 ((n) & 0x3FFF) << 16)

#define	PACKET3_WAIT_REG_MEM				0x3C
#define		WAIT_REG_MEM_FUNCTION(x)                ((x) << 0)
		/* 0 - always
		 * 1 - <
		 * 2 - <=
		 * 3 - ==
		 * 4 - !=
		 * 5 - >=
		 * 6 - >
		 */
#define		WAIT_REG_MEM_MEM_SPACE(x)               ((x) << 4)
		/* 0 - reg
		 * 1 - mem
		 */
#define		WAIT_REG_MEM_OPERATION(x)               ((x) << 6)
		/* 0 - wait_reg_mem
		 * 1 - wr_wait_wr_reg
		 */
#define		WAIT_REG_MEM_ENGINE(x)                  ((x) << 8)
		/* 0 - me
		 * 1 - pfp
		 */

static  amdgpu_device_handle device_handle;
static  uint32_t  major_version;
static  uint32_t  minor_version;

static pthread_t stress_thread;
static uint32_t *ptr;

static void amdgpu_deadlock_helper(unsigned ip_type);
static void amdgpu_deadlock_gfx(void);
static void amdgpu_deadlock_compute(void);

CU_BOOL suite_deadlock_tests_enable(void)
{
	CU_BOOL enable = CU_TRUE;

	if (amdgpu_device_initialize(drm_amdgpu[0], &major_version,
					     &minor_version, &device_handle))
		return CU_FALSE;

	if (device_handle->info.family_id == AMDGPU_FAMILY_AI ||
	    device_handle->info.family_id == AMDGPU_FAMILY_SI) {
		printf("\n\nCurrently hangs the CP on this ASIC, deadlock suite disabled\n");
		enable = CU_FALSE;
	}

	if (amdgpu_device_deinitialize(device_handle))
		return CU_FALSE;

	return enable;
}

int suite_deadlock_tests_init(void)
{
	int r;

	r = amdgpu_device_initialize(drm_amdgpu[0], &major_version,
				   &minor_version, &device_handle);

	if (r) {
		if ((r == -EACCES) && (errno == EACCES))
			printf("\n\nError:%s. "
				"Hint:Try to run this test program as root.",
				strerror(errno));
		return CUE_SINIT_FAILED;
	}

	return CUE_SUCCESS;
}

int suite_deadlock_tests_clean(void)
{
	int r = amdgpu_device_deinitialize(device_handle);

	if (r == 0)
		return CUE_SUCCESS;
	else
		return CUE_SCLEAN_FAILED;
}


CU_TestInfo deadlock_tests[] = {
	{ "gfx ring block test",  amdgpu_deadlock_gfx },
	{ "compute ring block test",  amdgpu_deadlock_compute },
	CU_TEST_INFO_NULL,
};

static void *write_mem_address(void *data)
{
	int i;

	/* useconds_t range is [0, 1,000,000] so use loop for waits > 1s */
	for (i = 0; i < WRITE_MEM_ADDRESS_DELAY_MS; i++)
		usleep(1000);

	ptr[256] = 0x1;

	return 0;
}

static void amdgpu_deadlock_gfx(void)
{
	amdgpu_deadlock_helper(AMDGPU_HW_IP_GFX);
}

static void amdgpu_deadlock_compute(void)
{
	amdgpu_deadlock_helper(AMDGPU_HW_IP_COMPUTE);
}

static void amdgpu_deadlock_helper(unsigned ip_type)
{
	amdgpu_context_handle context_handle;
	amdgpu_bo_handle ib_result_handle;
	void *ib_result_cpu;
	uint64_t ib_result_mc_address;
	struct amdgpu_cs_request ibs_request;
	struct amdgpu_cs_ib_info ib_info;
	struct amdgpu_cs_fence fence_status;
	uint32_t expired;
	int i, r;
	amdgpu_bo_list_handle bo_list;
	amdgpu_va_handle va_handle;

	r = pthread_create(&stress_thread, NULL, write_mem_address, NULL);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_cs_ctx_create(device_handle, &context_handle);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_bo_alloc_and_map(device_handle, 4096, 4096,
			AMDGPU_GEM_DOMAIN_GTT, 0,
						    &ib_result_handle, &ib_result_cpu,
						    &ib_result_mc_address, &va_handle);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_get_bo_list(device_handle, ib_result_handle, NULL,
			       &bo_list);
	CU_ASSERT_EQUAL(r, 0);

	ptr = ib_result_cpu;

	ptr[0] = PACKET3(PACKET3_WAIT_REG_MEM, 5);
	ptr[1] = (WAIT_REG_MEM_MEM_SPACE(1) | /* memory */
			 WAIT_REG_MEM_FUNCTION(4) | /* != */
			 WAIT_REG_MEM_ENGINE(0));  /* me */
	ptr[2] = (ib_result_mc_address + 256*4) & 0xfffffffc;
	ptr[3] = ((ib_result_mc_address + 256*4) >> 32) & 0xffffffff;
	ptr[4] = 0x00000000; /* reference value */
	ptr[5] = 0xffffffff; /* and mask */
	ptr[6] = 0x00000004; /* poll interval */

	for (i = 7; i < 16; ++i)
		ptr[i] = 0xffff1000;


	ptr[256] = 0x0; /* the memory we wait on to change */



	memset(&ib_info, 0, sizeof(struct amdgpu_cs_ib_info));
	ib_info.ib_mc_address = ib_result_mc_address;
	ib_info.size = 16;

	memset(&ibs_request, 0, sizeof(struct amdgpu_cs_request));
	ibs_request.ip_type = ip_type;
	ibs_request.ring = 0;
	ibs_request.number_of_ibs = 1;
	ibs_request.ibs = &ib_info;
	ibs_request.resources = bo_list;
	ibs_request.fence_info.handle = NULL;

	for (i = 0; i < 200; i++) {
		r = amdgpu_cs_submit(context_handle, 0,&ibs_request, 1);
		CU_ASSERT_EQUAL((r == 0 || r == -ECANCELED), 1);

	}

	memset(&fence_status, 0, sizeof(struct amdgpu_cs_fence));
	fence_status.context = context_handle;
	fence_status.ip_type = ip_type;
	fence_status.ip_instance = 0;
	fence_status.ring = 0;
	fence_status.fence = ibs_request.seq_no;

	r = amdgpu_cs_query_fence_status(&fence_status,
			AMDGPU_TIMEOUT_INFINITE,0, &expired);
	CU_ASSERT_EQUAL((r == 0 || r == -ECANCELED), 1);

	pthread_join(stress_thread, NULL);

	r = amdgpu_bo_list_destroy(bo_list);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_bo_unmap_and_free(ib_result_handle, va_handle,
				     ib_result_mc_address, 4096);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_cs_ctx_free(context_handle);
	CU_ASSERT_EQUAL(r, 0);
}
@


1.1
log
@Initial revision
@
text
@@


1.1.1.1
log
@initial import of libdrm-2.4.91
@
text
@@


1.1.1.2
log
@initial import of libdrm-2.4.96
@
text
@d24 4
a86 2
int use_uc_mtype = 0;

d99 2
a100 1
	if (device_handle->info.family_id == AMDGPU_FAMILY_SI) {
a104 3
	if (device_handle->info.family_id >= AMDGPU_FAMILY_AI)
		use_uc_mtype = 1;

d189 2
a190 2
	r = amdgpu_bo_alloc_and_map_raw(device_handle, 4096, 4096,
			AMDGPU_GEM_DOMAIN_GTT, 0, use_uc_mtype ? AMDGPU_VM_MTYPE_UC : 0,
@


1.1.1.3
log
@initial import of libdrm-2.4.97
@
text
@a75 23
#define	PACKET3_WRITE_DATA				0x37
#define		WRITE_DATA_DST_SEL(x)                   ((x) << 8)
		/* 0 - register
		 * 1 - memory (sync - via GRBM)
		 * 2 - gl2
		 * 3 - gds
		 * 4 - reserved
		 * 5 - memory (async - direct)
		 */
#define		WR_ONE_ADDR                             (1 << 16)
#define		WR_CONFIRM                              (1 << 20)
#define		WRITE_DATA_CACHE_POLICY(x)              ((x) << 25)
		/* 0 - LRU
		 * 1 - Stream
		 */
#define		WRITE_DATA_ENGINE_SEL(x)                ((x) << 30)
		/* 0 - me
		 * 1 - pfp
		 * 2 - ce
		 */

#define mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR                                      0x54f

a87 2
static void amdgpu_illegal_reg_access();
static void amdgpu_illegal_mem_access();
d97 2
a98 8
	/*
	 * Only enable for ASICs supporting GPU reset and for which it's enabled
	 * by default (currently GFX8/9 dGPUS)
	 */
	if (device_handle->info.family_id != AMDGPU_FAMILY_VI &&
	    device_handle->info.family_id != AMDGPU_FAMILY_AI &&
	    device_handle->info.family_id != AMDGPU_FAMILY_CI) {
		printf("\n\nGPU reset is not enabled for the ASIC, deadlock suite disabled\n");
d141 2
a142 4
	{ "gfx ring block test (set amdgpu.lockup_timeout=50)", amdgpu_deadlock_gfx },
	{ "compute ring block test (set amdgpu.lockup_timeout=50)", amdgpu_deadlock_compute },
	{ "illegal reg access test", amdgpu_illegal_reg_access },
	{ "illegal mem access test (set amdgpu.vm_fault_stop=2)", amdgpu_illegal_mem_access },
a259 87

static void bad_access_helper(int reg_access)
{
	amdgpu_context_handle context_handle;
	amdgpu_bo_handle ib_result_handle;
	void *ib_result_cpu;
	uint64_t ib_result_mc_address;
	struct amdgpu_cs_request ibs_request;
	struct amdgpu_cs_ib_info ib_info;
	struct amdgpu_cs_fence fence_status;
	uint32_t expired;
	int i, r;
	amdgpu_bo_list_handle bo_list;
	amdgpu_va_handle va_handle;

	r = amdgpu_cs_ctx_create(device_handle, &context_handle);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_bo_alloc_and_map_raw(device_handle, 4096, 4096,
			AMDGPU_GEM_DOMAIN_GTT, 0, 0,
							&ib_result_handle, &ib_result_cpu,
							&ib_result_mc_address, &va_handle);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_get_bo_list(device_handle, ib_result_handle, NULL,
				   &bo_list);
	CU_ASSERT_EQUAL(r, 0);

	ptr = ib_result_cpu;
	i = 0;

	ptr[i++] = PACKET3(PACKET3_WRITE_DATA, 3);
	ptr[i++] = (reg_access ? WRITE_DATA_DST_SEL(0) : WRITE_DATA_DST_SEL(5))| WR_CONFIRM;
	ptr[i++] = reg_access ? mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR : 0xdeadbee0;
	ptr[i++] = 0;
	ptr[i++] = 0xdeadbeef;

	for (; i < 16; ++i)
		ptr[i] = 0xffff1000;

	memset(&ib_info, 0, sizeof(struct amdgpu_cs_ib_info));
	ib_info.ib_mc_address = ib_result_mc_address;
	ib_info.size = 16;

	memset(&ibs_request, 0, sizeof(struct amdgpu_cs_request));
	ibs_request.ip_type = AMDGPU_HW_IP_GFX;
	ibs_request.ring = 0;
	ibs_request.number_of_ibs = 1;
	ibs_request.ibs = &ib_info;
	ibs_request.resources = bo_list;
	ibs_request.fence_info.handle = NULL;

	r = amdgpu_cs_submit(context_handle, 0,&ibs_request, 1);
	CU_ASSERT_EQUAL((r == 0 || r == -ECANCELED), 1);


	memset(&fence_status, 0, sizeof(struct amdgpu_cs_fence));
	fence_status.context = context_handle;
	fence_status.ip_type = AMDGPU_HW_IP_GFX;
	fence_status.ip_instance = 0;
	fence_status.ring = 0;
	fence_status.fence = ibs_request.seq_no;

	r = amdgpu_cs_query_fence_status(&fence_status,
			AMDGPU_TIMEOUT_INFINITE,0, &expired);
	CU_ASSERT_EQUAL((r == 0 || r == -ECANCELED), 1);

	r = amdgpu_bo_list_destroy(bo_list);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_bo_unmap_and_free(ib_result_handle, va_handle,
					 ib_result_mc_address, 4096);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_cs_ctx_free(context_handle);
	CU_ASSERT_EQUAL(r, 0);
}

static void amdgpu_illegal_reg_access()
{
	bad_access_helper(1);
}

static void amdgpu_illegal_mem_access()
{
	bad_access_helper(0);
}
@


1.1.1.4
log
@initial import of libdrm-2.4.99
@
text
@a98 3
#define SDMA_PKT_HEADER_OP(x)	(x & 0xff)
#define SDMA_OP_POLL_REGMEM  8

a112 1
static void amdgpu_deadlock_sdma(void);
a173 1
	{ "sdma ring block test (set amdgpu.lockup_timeout=50)", amdgpu_deadlock_sdma },
d263 1
a293 97
static void amdgpu_deadlock_sdma(void)
{
	amdgpu_context_handle context_handle;
	amdgpu_bo_handle ib_result_handle;
	void *ib_result_cpu;
	uint64_t ib_result_mc_address;
	struct amdgpu_cs_request ibs_request;
	struct amdgpu_cs_ib_info ib_info;
	struct amdgpu_cs_fence fence_status;
	uint32_t expired;
	int i, r;
	amdgpu_bo_list_handle bo_list;
	amdgpu_va_handle va_handle;
	struct drm_amdgpu_info_hw_ip info;
	uint32_t ring_id;

	r = amdgpu_query_hw_ip_info(device_handle, AMDGPU_HW_IP_DMA, 0, &info);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_cs_ctx_create(device_handle, &context_handle);
	CU_ASSERT_EQUAL(r, 0);

	for (ring_id = 0; (1 << ring_id) & info.available_rings; ring_id++) {
		r = pthread_create(&stress_thread, NULL, write_mem_address, NULL);
		CU_ASSERT_EQUAL(r, 0);

		r = amdgpu_bo_alloc_and_map_raw(device_handle, 4096, 4096,
				AMDGPU_GEM_DOMAIN_GTT, 0, use_uc_mtype ? AMDGPU_VM_MTYPE_UC : 0,
							    &ib_result_handle, &ib_result_cpu,
							    &ib_result_mc_address, &va_handle);
		CU_ASSERT_EQUAL(r, 0);

		r = amdgpu_get_bo_list(device_handle, ib_result_handle, NULL,
				       &bo_list);
		CU_ASSERT_EQUAL(r, 0);

		ptr = ib_result_cpu;
		i = 0;

		ptr[i++] = SDMA_PKT_HEADER_OP(SDMA_OP_POLL_REGMEM) |
				(0 << 26) | /* WAIT_REG_MEM */
				(4 << 28) | /* != */
				(1 << 31); /* memory */
		ptr[i++] = (ib_result_mc_address + 256*4) & 0xfffffffc;
		ptr[i++] = ((ib_result_mc_address + 256*4) >> 32) & 0xffffffff;
		ptr[i++] = 0x00000000; /* reference value */
		ptr[i++] = 0xffffffff; /* and mask */
		ptr[i++] =  4 | /* poll interval */
				(0xfff << 16); /* retry count */

		for (; i < 16; i++)
			ptr[i] = 0;

		ptr[256] = 0x0; /* the memory we wait on to change */

		memset(&ib_info, 0, sizeof(struct amdgpu_cs_ib_info));
		ib_info.ib_mc_address = ib_result_mc_address;
		ib_info.size = 16;

		memset(&ibs_request, 0, sizeof(struct amdgpu_cs_request));
		ibs_request.ip_type = AMDGPU_HW_IP_DMA;
		ibs_request.ring = ring_id;
		ibs_request.number_of_ibs = 1;
		ibs_request.ibs = &ib_info;
		ibs_request.resources = bo_list;
		ibs_request.fence_info.handle = NULL;

		for (i = 0; i < 200; i++) {
			r = amdgpu_cs_submit(context_handle, 0,&ibs_request, 1);
			CU_ASSERT_EQUAL((r == 0 || r == -ECANCELED), 1);

		}

		memset(&fence_status, 0, sizeof(struct amdgpu_cs_fence));
		fence_status.context = context_handle;
		fence_status.ip_type = AMDGPU_HW_IP_DMA;
		fence_status.ip_instance = 0;
		fence_status.ring = ring_id;
		fence_status.fence = ibs_request.seq_no;

		r = amdgpu_cs_query_fence_status(&fence_status,
				AMDGPU_TIMEOUT_INFINITE,0, &expired);
		CU_ASSERT_EQUAL((r == 0 || r == -ECANCELED), 1);

		pthread_join(stress_thread, NULL);

		r = amdgpu_bo_list_destroy(bo_list);
		CU_ASSERT_EQUAL(r, 0);

		r = amdgpu_bo_unmap_and_free(ib_result_handle, va_handle,
					     ib_result_mc_address, 4096);
		CU_ASSERT_EQUAL(r, 0);
	}
	r = amdgpu_cs_ctx_free(context_handle);
	CU_ASSERT_EQUAL(r, 0);
}

@


1.1.1.5
log
@initial import of libdrm-2.4.102
@
text
@d27 1
a27 1
#if HAVE_ALLOCA_H
a116 6
static void amdgpu_dispatch_hang_gfx(void);
static void amdgpu_dispatch_hang_compute(void);
static void amdgpu_dispatch_hang_slow_gfx(void);
static void amdgpu_dispatch_hang_slow_compute(void);
static void amdgpu_draw_hang_gfx(void);
static void amdgpu_draw_hang_slow_gfx(void);
a180 6
	{ "gfx ring bad dispatch test (set amdgpu.lockup_timeout=50)", amdgpu_dispatch_hang_gfx },
	{ "compute ring bad dispatch test (set amdgpu.lockup_timeout=50,50)", amdgpu_dispatch_hang_compute },
	{ "gfx ring bad slow dispatch test (set amdgpu.lockup_timeout=50)", amdgpu_dispatch_hang_slow_gfx },
	{ "compute ring bad slow dispatch test (set amdgpu.lockup_timeout=50,50)", amdgpu_dispatch_hang_slow_compute },
	{ "gfx ring bad draw test (set amdgpu.lockup_timeout=50)", amdgpu_draw_hang_gfx },
	{ "gfx ring slow bad draw test (set amdgpu.lockup_timeout=50)", amdgpu_draw_hang_slow_gfx },
a480 54

static void amdgpu_dispatch_hang_gfx(void)
{
	amdgpu_dispatch_hang_helper(device_handle, AMDGPU_HW_IP_GFX);
}

static void amdgpu_dispatch_hang_compute(void)
{
	amdgpu_dispatch_hang_helper(device_handle, AMDGPU_HW_IP_COMPUTE);
}

static void amdgpu_dispatch_hang_slow_gfx(void)
{
	amdgpu_dispatch_hang_slow_helper(device_handle, AMDGPU_HW_IP_GFX);
}

static void amdgpu_dispatch_hang_slow_compute(void)
{
	amdgpu_dispatch_hang_slow_helper(device_handle, AMDGPU_HW_IP_COMPUTE);
}

static void amdgpu_draw_hang_gfx(void)
{
	int r;
	struct drm_amdgpu_info_hw_ip info;
	uint32_t ring_id;

	r = amdgpu_query_hw_ip_info(device_handle, AMDGPU_HW_IP_GFX, 0, &info);
	CU_ASSERT_EQUAL(r, 0);
	if (!info.available_rings)
		printf("SKIP ... as there's no graphic ring\n");

	for (ring_id = 0; (1 << ring_id) & info.available_rings; ring_id++) {
		amdgpu_memcpy_draw_test(device_handle, ring_id, 0);
		amdgpu_memcpy_draw_test(device_handle, ring_id, 1);
		amdgpu_memcpy_draw_test(device_handle, ring_id, 0);
	}
}

static void amdgpu_draw_hang_slow_gfx(void)
{
	struct drm_amdgpu_info_hw_ip info;
	uint32_t ring_id;
	int r;

	r = amdgpu_query_hw_ip_info(device_handle, AMDGPU_HW_IP_GFX, 0, &info);
	CU_ASSERT_EQUAL(r, 0);

	for (ring_id = 0; (1 << ring_id) & info.available_rings; ring_id++) {
		amdgpu_memcpy_draw_test(device_handle, ring_id, 0);
		amdgpu_memcpy_draw_hang_slow_test(device_handle, ring_id);
		amdgpu_memcpy_draw_test(device_handle, ring_id, 0);
	}
}
@


1.1.1.6
log
@initial import of libdrm-2.4.105
@
text
@a126 1
	uint32_t asic_id;
a142 9
	asic_id = device_handle->info.asic_id;
	if (asic_is_arcturus(asic_id)) {
		if (amdgpu_set_test_active("Deadlock Tests",
					"gfx ring block test (set amdgpu.lockup_timeout=50)",
					CU_FALSE))
			fprintf(stderr, "test deactivation failed - %s\n",
				CU_get_error_msg());
	}

@


1.1.1.7
log
@initial import of libdrm-2.4.107
@
text
@a108 4
static uint32_t family_id;
static uint32_t chip_rev;
static uint32_t chip_id;

d127 1
a132 4
	family_id = device_handle->info.family_id;
	chip_id = device_handle->info.chip_external_rev;
	chip_rev = device_handle->info.chip_rev;

d137 3
a139 3
	if (family_id != AMDGPU_FAMILY_VI &&
	    family_id != AMDGPU_FAMILY_AI &&
	    family_id != AMDGPU_FAMILY_CI) {
d144 2
a145 1
	if (asic_is_gfx_pipe_removed(family_id, chip_id, chip_rev)) {
@


1.1.1.8
log
@initial import of libdrm-2.4.112
@
text
@d142 1
a142 2
	 * by default (currently GFX8+ dGPUS and gfx9+ APUs).  Note that Raven1
	 * did not support GPU reset, but newer variants do.
d144 3
a146 4
	if (family_id == AMDGPU_FAMILY_SI ||
	    family_id == AMDGPU_FAMILY_KV ||
	    family_id == AMDGPU_FAMILY_CZ ||
	    family_id == AMDGPU_FAMILY_RV) {
d534 1
a534 1
	uint32_t ring_id, version;
a540 6
	version = info.hw_ip_version_major;
	if (version != 9 && version != 10) {
		printf("SKIP ... unsupported gfx version %d\n", version);
		return;
	}

d542 3
a544 3
		amdgpu_memcpy_draw_test(device_handle, ring_id, version, 0);
		amdgpu_memcpy_draw_test(device_handle, ring_id, version, 1);
		amdgpu_memcpy_draw_test(device_handle, ring_id, version, 0);
d551 1
a551 1
	uint32_t ring_id, version;
a556 6
	version = info.hw_ip_version_major;
	if (version != 9 && version != 10) {
		printf("SKIP ... unsupported gfx version %d\n", version);
		return;
	}

d558 3
a560 3
		amdgpu_memcpy_draw_test(device_handle, ring_id, version, 0);
		amdgpu_memcpy_draw_hang_slow_test(device_handle, ring_id, version);
		amdgpu_memcpy_draw_test(device_handle, ring_id, version, 0);
@


1.1.1.9
log
@initial import of libdrm-2.4.114
@
text
@a126 2
static void amdgpu_hang_sdma(void);
static void amdgpu_hang_slow_sdma(void);
a210 2
	{ "sdma ring corrupted header test (set amdgpu.lockup_timeout=50)", amdgpu_hang_sdma },
	{ "sdma ring slow linear copy test (set amdgpu.lockup_timeout=50)", amdgpu_hang_slow_sdma },
d514 1
a514 1
	amdgpu_test_dispatch_hang_helper(device_handle, AMDGPU_HW_IP_GFX);
d516 1
d519 1
a519 1
	amdgpu_test_dispatch_hang_helper(device_handle, AMDGPU_HW_IP_COMPUTE);
d521 1
d524 1
a524 1
	amdgpu_test_dispatch_hang_slow_helper(device_handle, AMDGPU_HW_IP_GFX);
d526 1
d529 1
a529 1
	amdgpu_test_dispatch_hang_slow_helper(device_handle, AMDGPU_HW_IP_COMPUTE);
d531 1
d534 3
a536 30
	amdgpu_test_draw_hang_helper(device_handle);
}
static void amdgpu_draw_hang_slow_gfx(void)
{
	amdgpu_test_draw_hang_slow_helper(device_handle);
}

#define DMA_CORRUPTED_HEADER_HANG	1
#define DMA_SLOW_LINEARCOPY_HANG	2

static void amdgpu_hang_sdma_helper(unsigned hang_type)
{
	const int sdma_write_length = 1024;
	amdgpu_context_handle context_handle;
	amdgpu_bo_handle ib_result_handle;
	amdgpu_bo_handle bo1, bo2;
	amdgpu_bo_handle resources[3];
	amdgpu_bo_list_handle bo_list;
	void *ib_result_cpu;
	struct amdgpu_cs_ib_info ib_info;
	struct amdgpu_cs_request ibs_request;
	struct amdgpu_cs_fence fence_status;
	uint64_t bo1_mc, bo2_mc;
	uint64_t ib_result_mc_address;
	volatile unsigned char *bo1_cpu, *bo2_cpu;
	amdgpu_va_handle bo1_va_handle, bo2_va_handle;
	amdgpu_va_handle va_handle;
	struct drm_amdgpu_info_hw_ip hw_ip_info;
	int i, j, r;
	uint32_t expired, ib_size;
d538 1
a538 1
	r = amdgpu_query_hw_ip_info(device_handle, AMDGPU_HW_IP_DMA, 0, &hw_ip_info);
d540 2
d543 5
a547 2
	r = amdgpu_cs_ctx_create(device_handle, &context_handle);
	CU_ASSERT_EQUAL(r, 0);
d549 6
a554 4
	if (hang_type == DMA_CORRUPTED_HEADER_HANG)
		ib_size = 4096;
	else
		ib_size = 4096 * 0x20000;
d556 5
a560 5
	r = amdgpu_bo_alloc_and_map(device_handle, ib_size, 4096,
				    AMDGPU_GEM_DOMAIN_GTT, 0,
				    &ib_result_handle, &ib_result_cpu,
				    &ib_result_mc_address, &va_handle);
	CU_ASSERT_EQUAL(r, 0);
d562 1
a562 6
	r = amdgpu_bo_alloc_and_map(device_handle,
				    sdma_write_length, 4096,
				    AMDGPU_GEM_DOMAIN_GTT,
				    0, &bo1,
				    (void**)&bo1_cpu, &bo1_mc,
				    &bo1_va_handle);
d565 5
a569 2
	/* set bo1 */
	memset((void*)bo1_cpu, 0xaa, sdma_write_length);
d571 4
a574 46
	/* allocate UC bo2 for sDMA use */
	r = amdgpu_bo_alloc_and_map(device_handle,
				    sdma_write_length, 4096,
				    AMDGPU_GEM_DOMAIN_GTT,
				    0, &bo2,
				    (void**)&bo2_cpu, &bo2_mc,
				    &bo2_va_handle);
	CU_ASSERT_EQUAL(r, 0);

	/* clear bo2 */
	memset((void*)bo2_cpu, 0, sdma_write_length);

	resources[0] = bo1;
	resources[1] = bo2;
	resources[2] = ib_result_handle;
	r = amdgpu_bo_list_create(device_handle, 3,
				  resources, NULL, &bo_list);

	/* fulfill PM4: with bad copy linear header */
	ptr = ib_result_cpu;
	i = 0;
	if (hang_type == DMA_CORRUPTED_HEADER_HANG) {
		ptr[i++] = 0x23decd3d;
		ptr[i++] = sdma_write_length - 1;
		ptr[i++] = 0;
		ptr[i++] = 0xffffffff & bo1_mc;
		ptr[i++] = (0xffffffff00000000 & bo1_mc) >> 32;
		ptr[i++] = 0xffffffff & bo2_mc;
		ptr[i++] = (0xffffffff00000000 & bo2_mc) >> 32;
	} else {
		for (j = 1; j < 0x20000; j++) {
			ptr[i++] = 0x1;
			ptr[i++] = sdma_write_length - 1;
			ptr[i++] = 0;
			ptr[i++] = 0xffffffff & bo1_mc;
			ptr[i++] = (0xffffffff00000000 & bo1_mc) >> 32;
			ptr[i++] = 0xffffffff & bo2_mc;
			ptr[i++] = (0xffffffff00000000 & bo2_mc) >> 32;
			ptr[i++] = 0x1;
			ptr[i++] = sdma_write_length - 1;
			ptr[i++] = 0;
			ptr[i++] = 0xffffffff & bo2_mc;
			ptr[i++] = (0xffffffff00000000 & bo2_mc) >> 32;
			ptr[i++] = 0xffffffff & bo1_mc;
			ptr[i++] = (0xffffffff00000000 & bo1_mc) >> 32;
		}
a575 56

	/* exec command */
	memset(&ib_info, 0, sizeof(struct amdgpu_cs_ib_info));
	ib_info.ib_mc_address = ib_result_mc_address;
	ib_info.size = i;

	memset(&ibs_request, 0, sizeof(struct amdgpu_cs_request));
	ibs_request.ip_type = AMDGPU_HW_IP_DMA;
	ibs_request.ring = 0;
	ibs_request.number_of_ibs = 1;
	ibs_request.ibs = &ib_info;
	ibs_request.resources = bo_list;
	ibs_request.fence_info.handle = NULL;

	r = amdgpu_cs_submit(context_handle, 0, &ibs_request, 1);
	CU_ASSERT_EQUAL(r, 0);

	memset(&fence_status, 0, sizeof(struct amdgpu_cs_fence));
	fence_status.context = context_handle;
	fence_status.ip_type = AMDGPU_HW_IP_DMA;
	fence_status.ip_instance = 0;
	fence_status.ring = 0;
	fence_status.fence = ibs_request.seq_no;

	r = amdgpu_cs_query_fence_status(&fence_status,
					 AMDGPU_TIMEOUT_INFINITE,
					 0, &expired);
	CU_ASSERT_EQUAL((r == 0 || r == -ECANCELED), 1);

	r = amdgpu_bo_list_destroy(bo_list);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_bo_unmap_and_free(ib_result_handle, va_handle,
				     ib_result_mc_address, 4096);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_bo_unmap_and_free(bo1, bo1_va_handle, bo1_mc,
				     sdma_write_length);
	CU_ASSERT_EQUAL(r, 0);

	r = amdgpu_bo_unmap_and_free(bo2, bo2_va_handle, bo2_mc,
				     sdma_write_length);
	CU_ASSERT_EQUAL(r, 0);

	/* end of test */
	r = amdgpu_cs_ctx_free(context_handle);
	CU_ASSERT_EQUAL(r, 0);
}

static void amdgpu_hang_sdma(void)
{
	amdgpu_hang_sdma_helper(DMA_CORRUPTED_HEADER_HANG);
}
static void amdgpu_hang_slow_sdma(void)
{
	amdgpu_hang_sdma_helper(DMA_SLOW_LINEARCOPY_HANG);
@


