156 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			156 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
| /*
 | |
|  * Copyright (c) 2006-2023, RT-Thread Development Team
 | |
|  *
 | |
|  * SPDX-License-Identifier: Apache-2.0
 | |
|  *
 | |
|  * Change Logs:
 | |
|  * Date           Author       Notes
 | |
|  * 2021-9-16      GuEe-GUI     the first version
 | |
|  * 2021-11-11     GuEe-GUI     modify to virtio common interface
 | |
|  */
 | |
| 
 | |
| #ifndef __VIRTIO_H__
 | |
| #define __VIRTIO_H__
 | |
| 
 | |
| #include <rthw.h>
 | |
| #include <rtdef.h>
 | |
| 
 | |
| #ifdef RT_USING_SMART
 | |
| #include <mmu.h>
 | |
| #include <ioremap.h>
 | |
| #endif
 | |
| 
 | |
| #if RT_NAME_MAX < 16
 | |
| #error "Please set RT_NAME_MAX to at lest 16"
 | |
| #endif
 | |
| 
 | |
| #ifdef RT_USING_VIRTIO10
 | |
| #define RT_USING_VIRTIO_VERSION 0x1
 | |
| #endif
 | |
| 
 | |
| #include <virtio_mmio.h>
 | |
| #include <virtio_queue.h>
 | |
| 
 | |
| #define VIRTIO_MAGIC_VALUE          0x74726976 /* "virt" */
 | |
| 
 | |
| #define VIRTIO_STATUS_ACKNOWLEDGE   (1 << 0)
 | |
| #define VIRTIO_STATUS_DRIVER        (1 << 1)
 | |
| #define VIRTIO_STATUS_DRIVER_OK     (1 << 2)
 | |
| #define VIRTIO_STATUS_FEATURES_OK   (1 << 3)
 | |
| #define VIRTIO_STATUS_NEEDS_RESET   (1 << 6)
 | |
| #define VIRTIO_STATUS_FAILED        (1 << 7)
 | |
| 
 | |
| #define VIRTIO_F_NOTIFY_ON_EMPTY    24
 | |
| #define VIRTIO_F_ANY_LAYOUT         27
 | |
| #define VIRTIO_F_RING_INDIRECT_DESC 28
 | |
| #define VIRTIO_F_RING_EVENT_IDX     29
 | |
| #define VIRTIO_F_VERSION_1          32
 | |
| #define VIRTIO_F_RING_PACKED        34
 | |
| 
 | |
| #ifdef RT_USING_SMART
 | |
| #define VIRTIO_VA2PA(vaddr)         ((rt_ubase_t)rt_kmem_v2p(vaddr))
 | |
| #define VIRTIO_PA2VA(paddr)         ((rt_ubase_t)rt_ioremap((void *)paddr, ARCH_PAGE_SIZE))
 | |
| #else
 | |
| #define VIRTIO_VA2PA(vaddr)         ((rt_ubase_t)vaddr)
 | |
| #define VIRTIO_PA2VA(paddr)         ((rt_ubase_t)paddr)
 | |
| #endif /* RT_USING_SMART */
 | |
| #define VIRTIO_PAGE_SHIFT           12
 | |
| #define VIRTIO_PAGE_SIZE            (1 << VIRTIO_PAGE_SHIFT)
 | |
| #define VIRTIO_PAGE_ALIGN(addr)     (RT_ALIGN(addr, VIRTIO_PAGE_SIZE))
 | |
| 
 | |
| enum
 | |
| {
 | |
|     /* virtio 1.0 */
 | |
|     VIRTIO_DEVICE_ID_INVALID        = 0,    /* Invalid device */
 | |
|     VIRTIO_DEVICE_ID_NET            = 1,    /* Net */
 | |
|     VIRTIO_DEVICE_ID_BLOCK          = 2,    /* Block */
 | |
|     VIRTIO_DEVICE_ID_CONSOLE        = 3,    /* Console */
 | |
|     VIRTIO_DEVICE_ID_RNG            = 4,    /* Rng */
 | |
|     VIRTIO_DEVICE_ID_BALLOON        = 5,    /* Balloon */
 | |
|     VIRTIO_DEVICE_ID_IOMEM          = 6,    /* IO memory */
 | |
|     VIRTIO_DEVICE_ID_RPMSG          = 7,    /* Remote processor messaging */
 | |
|     VIRTIO_DEVICE_ID_SCSI           = 8,    /* SCSI */
 | |
|     VIRTIO_DEVICE_ID_9P             = 9,    /* 9p console */
 | |
|     VIRTIO_DEVICE_ID_MAC80211_WLAN  = 10,   /* Mac80211 wlan */
 | |
|     VIRTIO_DEVICE_ID_RPROC_SERIAL   = 11,   /* Remoteproc serial link */
 | |
|     VIRTIO_DEVICE_ID_CAIF           = 12,   /* CAIF */
 | |
|     VIRTIO_DEVICE_ID_MEM_BALLOON    = 13,   /* Memory balloon */
 | |
|     VIRTIO_DEVICE_ID_GPU            = 16,   /* GPU */
 | |
|     VIRTIO_DEVICE_ID_TIME           = 17,   /* Timer/clock device */
 | |
|     VIRTIO_DEVICE_ID_INPUT          = 18,   /* Input */
 | |
|     /* virtio 1.1 */
 | |
|     VIRTIO_DEVICE_ID_SOCKET         = 19,   /* Socket device */
 | |
|     VIRTIO_DEVICE_ID_CRYPTO         = 20,   /* Crypto device */
 | |
|     VIRTIO_DEVICE_ID_SIG_DIS_MOD    = 21,   /* Signal Distribution Module */
 | |
|     VIRTIO_DEVICE_ID_PSTORE         = 22,   /* Pstore device */
 | |
|     VIRTIO_DEVICE_ID_IOMMU          = 23,   /* IOMMU device */
 | |
|     VIRTIO_DEVICE_ID_MEM            = 24,   /* Memory device */
 | |
|     /* virtio 1.2 */
 | |
|     VIRTIO_DEVICE_ID_AUDIO          = 25,   /* Audio device */
 | |
|     VIRTIO_DEVICE_ID_FS             = 26,   /* File system device */
 | |
|     VIRTIO_DEVICE_ID_PMEM           = 27,   /* PMEM device */
 | |
|     VIRTIO_DEVICE_ID_RPMB           = 28,   /* RPMB device */
 | |
|     VIRTIO_DEVICE_ID_MAC80211_HWSIM = 29,   /* Mac80211 hwsim wireless simulation device */
 | |
|     VIRTIO_DEVICE_ID_VIDEO_ENCODER  = 30,   /* Video encoder device */
 | |
|     VIRTIO_DEVICE_ID_VIDEO_DECODER  = 31,   /* Video decoder device */
 | |
|     VIRTIO_DEVICE_ID_SCMI           = 32,   /* SCMI device */
 | |
|     VIRTIO_DEVICE_ID_NITRO_SEC_MOD  = 33,   /* NitroSecureModule */
 | |
|     VIRTIO_DEVICE_ID_I2C_ADAPTER    = 34,   /* I2C adapter */
 | |
|     VIRTIO_DEVICE_ID_WATCHDOG       = 35,   /* Watchdog */
 | |
|     VIRTIO_DEVICE_ID_CAN            = 36,   /* CAN device */
 | |
|     VIRTIO_DEVICE_ID_DMABUF         = 37,   /* Virtio dmabuf */
 | |
|     VIRTIO_DEVICE_ID_PARAM_SERV     = 38,   /* Parameter Server */
 | |
|     VIRTIO_DEVICE_ID_AUDIO_POLICY   = 39,   /* Audio policy device */
 | |
|     VIRTIO_DEVICE_ID_BT             = 40,   /* Bluetooth device */
 | |
|     VIRTIO_DEVICE_ID_GPIO           = 41,   /* GPIO device */
 | |
|     VIRTIO_DEVICE_ID_RDMA           = 42,   /* RDMA device */
 | |
| 
 | |
|     VIRTIO_DEVICE_TYPE_SIZE
 | |
| };
 | |
| 
 | |
| struct virtio_device
 | |
| {
 | |
|     rt_uint32_t irq;
 | |
| 
 | |
|     struct virtq *queues;
 | |
|     rt_size_t queues_num;
 | |
| 
 | |
|     union
 | |
|     {
 | |
|         rt_ubase_t *mmio_base;
 | |
|         struct virtio_mmio_config *mmio_config;
 | |
|     };
 | |
| 
 | |
| #ifdef RT_USING_SMP
 | |
|     struct rt_spinlock spinlock;
 | |
| #endif
 | |
| 
 | |
|     void *priv;
 | |
| };
 | |
| 
 | |
| typedef rt_err_t (*virtio_device_init_handler)(rt_ubase_t *mmio_base, rt_uint32_t irq);
 | |
| 
 | |
| void virtio_reset_device(struct virtio_device *dev);
 | |
| void virtio_status_acknowledge_driver(struct virtio_device *dev);
 | |
| void virtio_status_driver_ok(struct virtio_device *dev);
 | |
| void virtio_interrupt_ack(struct virtio_device *dev);
 | |
| rt_bool_t virtio_has_feature(struct virtio_device *dev, rt_uint32_t feature_bit);
 | |
| 
 | |
| rt_err_t virtio_queues_alloc(struct virtio_device *dev, rt_size_t queues_num);
 | |
| void virtio_queues_free(struct virtio_device *dev);
 | |
| rt_err_t virtio_queue_init(struct virtio_device *dev, rt_uint32_t queue_index, rt_size_t ring_size);
 | |
| void virtio_queue_destroy(struct virtio_device *dev, rt_uint32_t queue_index);
 | |
| void virtio_queue_notify(struct virtio_device *dev, rt_uint32_t queue_index);
 | |
| 
 | |
| void virtio_submit_chain(struct virtio_device *dev, rt_uint32_t queue_index, rt_uint16_t desc_index);
 | |
| 
 | |
| rt_uint16_t virtio_alloc_desc(struct virtio_device *dev, rt_uint32_t queue_index);
 | |
| void virtio_free_desc(struct virtio_device *dev, rt_uint32_t queue_index, rt_uint16_t desc_index);
 | |
| rt_err_t virtio_alloc_desc_chain(struct virtio_device *dev, rt_uint32_t queue_index, rt_size_t count,
 | |
|         rt_uint16_t *indexs);
 | |
| void virtio_free_desc_chain(struct virtio_device *dev, rt_uint32_t queue_index, rt_uint16_t desc_index);
 | |
| void virtio_fill_desc(struct virtio_device *dev, rt_uint32_t queue_index, rt_uint16_t desc_index,
 | |
|         rt_uint64_t addr, rt_uint32_t len, rt_uint16_t flags, rt_uint16_t next);
 | |
| 
 | |
| #endif /* __VIRTIO_H__ */
 |