]> Gitweb @ Texas Instruments - Open Source Git Repositories - git.TI.com/gitweb - processor-sdk/open-amp.git/blob - apps/machine/zynqmp/rsc_table.c
51a72ea94e5e2ab85f15cae053130002ff304223
[processor-sdk/open-amp.git] / apps / machine / zynqmp / rsc_table.c
1 /*
2  * Copyright (c) 2014, Mentor Graphics Corporation
3  * All rights reserved.
4  * Copyright (c) 2015 Xilinx, Inc. All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions are met:
8  *
9  * 1. Redistributions of source code must retain the above copyright notice,
10  *    this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright notice,
12  *    this list of conditions and the following disclaimer in the documentation
13  *    and/or other materials provided with the distribution.
14  * 3. Neither the name of Mentor Graphics Corporation nor the names of its
15  *    contributors may be used to endorse or promote products derived from this
16  *    software without specific prior written permission.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
22  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28  * POSSIBILITY OF SUCH DAMAGE.
29  */
31 /* This file populates resource table for BM remote
32  * for use by the Linux Master */
34 #include "openamp/open_amp.h"
35 #include "rsc_table.h"
37 /* Place resource table in special ELF section */
38 #define __section_t(S)          __attribute__((__section__(#S)))
39 #define __resource              __section_t(.resource_table)
41 #define RPMSG_IPU_C0_FEATURES        1
43 /* VirtIO rpmsg device id */
44 #define VIRTIO_ID_RPMSG_             7
46 /* Remote supports Name Service announcement */
47 #define VIRTIO_RPMSG_F_NS           0
49 #define NUM_VRINGS                  0x02
50 #define VRING_ALIGN                 0x1000
51 #define RING_TX                     0x3ED40000
52 #define RING_RX                     0x3ED44000
53 #define VRING_SIZE                  256
55 #define NUM_TABLE_ENTRIES           1
57 const struct remote_resource_table __resource resources = {
58         /* Version */
59         1,
61         /* NUmber of table entries */
62         NUM_TABLE_ENTRIES,
63         /* reserved fields */
64         {0, 0,},
66         /* Offsets of rsc entries */
67         {
68          offsetof(struct remote_resource_table, rpmsg_vdev),
69          },
71             /* Virtio device entry */
72         {RSC_VDEV, VIRTIO_ID_RPMSG_, 0, RPMSG_IPU_C0_FEATURES, 0, 0, 0,
73          NUM_VRINGS, {0, 0},
74          },
76         /* Vring rsc entry - part of vdev rsc entry */
77         {
78          RING_TX, VRING_ALIGN, VRING_SIZE, 1, 0},
79         {
80          RING_RX, VRING_ALIGN, VRING_SIZE, 2, 0},
81 };