~funderscore blog cgit wiki get in touch
aboutsummaryrefslogtreecommitdiff
blob: 5b94beda0abab76b70eb325ca3dde231fb6c51c1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/* SPDX-License-Identifier: GPL-2.0+ */
/*
 * (C) Copyright 2018
 * Mario Six, Guntermann & Drunck GmbH, mario.six@gdsys.cc
 */

#ifndef __asm_axi_h
#define __asm_axi_h

#define axi_emul_get_ops(dev)	((struct axi_emul_ops *)(dev)->driver->ops)

/**
 * axi_sandbox_get_emul() - Retrieve a pointer to a AXI emulation device
 * @bus:     The AXI bus from which to retrieve a emulation device
 * @address: The address of a transfer that should be handled by a emulation
 *	     device
 * @size:    A constant indicating the data width of the transfer that
 *	     should be handled by an emulation device
 * @emulp:   Pointer to a buffer receiving the emulation device that handles
 *	     the transfer specified by the address and length parameters
 *
 * To test the AXI uclass, we implement a simple AXI emulation device, which is
 * a virtual device on a AXI bus that exposes a simple storage interface: When
 * reading and writing from the device, the addresses are translated to offsets
 * within the device's storage. For write accesses the data is written to the
 * specified storage offset, and for read accesses the data is read from the
 * specified storage offset.
 *
 * A DTS entry might look like this:
 *
 * axi: axi@0 {
 *	compatible = "sandbox,axi";
 *	#address-cells = <0x1>;
 *	#size-cells = <0x1>;
 *	store@0 {
 *		compatible = "sandbox,sandbox_store";
 *		reg = <0x0 0x400>;
 *	};
 * };
 *
 * This function may then be used to retrieve the pointer to the sandbox_store
 * emulation device given the AXI bus device, and the data (address, data
 * width) of a AXI transfer which should be handled by a emulation device.
 *
 * Return: 0 of OK, -ENODEV if no device capable of handling the specified
 *	   transfer exists or the device could not be retrieved
 */
int axi_sandbox_get_emul(struct udevice *bus, ulong address,
			 const enum axi_size_t size, struct udevice **emulp);
/**
 * axi_get_store() - Get address of internal storage of a emulated AXI device
 * @dev:	Emulated AXI device to get the pointer of the internal storage
 *		for.
 * @storep:	Pointer to the internal storage of the emulated AXI device.
 *
 * To preset or read back the contents internal storage of the emulated AXI
 * device, this function returns the pointer to the storage. Changes to the
 * contents of the storage are reflected when using the AXI read/write API
 * methods, and vice versa, so by using this method expected read data can be
 * set up in advance, and written data can be checked in unit tests.
 *
 * Return: 0 if OK, -ve on error.
 */
int axi_get_store(struct udevice *dev, u8 **storep);

#endif /* __asm_axi_h */