1 /******************************************************************************
2 * Copyright (c) 2004, 2011 IBM Corporation
4 * This program and the accompanying materials
5 * are made available under the terms of the BSD License
6 * which accompanies this distribution, and is available at
7 * http://www.opensource.org/licenses/bsd-license.php
10 * IBM Corporation - initial implementation
11 *****************************************************************************/
14 #include <virtio-blk.h>
15 #include <virtio-9p.h>
16 #include <virtio-scsi.h>
17 #include <virtio-net.h>
19 /******** core virtio ********/
21 // : virtio-setup-vd ( -- dev )
22 PRIM(virtio_X2d_setup_X2d_vd)
23 PUSH; TOS.a = virtio_setup_vd();
26 // : virtio-vring-size ( queuesize -- ringsize )
27 PRIM(virtio_X2d_vring_X2d_size)
28 TOS.u = virtio_vring_size(TOS.u);
31 // : virtio-get-qsize ( dev queue -- queuesize )
32 PRIM(virtio_X2d_get_X2d_qsize)
33 int queue = TOS.u; POP;
34 TOS.u = virtio_get_qsize(TOS.a, queue);
37 // : virtio-get-config ( dev offset size -- val )
38 PRIM(virtio_X2d_get_X2d_config)
39 int size = TOS.u; POP;
40 int offset = TOS.u; POP;
41 TOS.u = virtio_get_config(TOS.a, offset, size);
44 // : virtio-set-qaddr ( dev queue qaddr -- )
45 PRIM(virtio_X2d_set_X2d_qaddr)
46 unsigned int qaddr = TOS.u; POP;
47 int queue = TOS.u; POP;
48 void *dev = TOS.a; POP;
49 virtio_set_qaddr(dev, queue, qaddr);
52 /******** virtio-blk ********/
54 // : virtio-blk-init ( dev -- blk-size)
55 PRIM(virtio_X2d_blk_X2d_init)
57 TOS.u = virtioblk_init(dev);
60 // : virtio-blk-shutdown ( dev -- )
61 PRIM(virtio_X2d_blk_X2d_shutdown)
62 void *dev = TOS.a; POP;
63 virtioblk_shutdown(dev);
66 // : virtio-blk-read ( dev blkno cnt reg -- #read )
67 PRIM(virtio_X2d_blk_X2d_read)
68 void *dev = TOS.a; POP;
69 long cnt = TOS.n; POP;
70 long blkno = TOS.n; POP;
72 TOS.n = virtioblk_read(dev, buf, blkno, cnt);
75 /******** virtio-fs ********/
77 // : virtio-fs-init ( dev tx rx size -- success )
78 PRIM(virtio_X2d_fs_X2d_init)
79 int size = TOS.n; POP;
80 void *rx = TOS.a; POP;
81 void *tx = TOS.a; POP;
84 TOS.n = virtio_9p_init(dev, tx, rx, size) == 0 ? -1 : 0;
87 // : virtio-fs-shutdown ( dev -- )
88 PRIM(virtio_X2d_fs_X2d_shutdown)
89 void *dev = TOS.a; POP;
91 virtio_9p_shutdown(dev);
94 // : virtio-fs-load ( dev buf str -- #read )
95 PRIM(virtio_X2d_fs_X2d_load)
96 char *str = TOS.a; POP;
97 void *buf = TOS.a; POP;
100 TOS.n = virtio_9p_load(dev, str, buf);
103 /******** virtio-scsi ********/
105 // : virtio-scsi-init ( dev -- success )
106 PRIM(virtio_X2d_scsi_X2d_init)
108 TOS.u = virtioscsi_init(dev);
111 // : virtio-scsi-shutdown ( dev -- )
112 PRIM(virtio_X2d_scsi_X2d_shutdown)
113 void *dev = TOS.a; POP;
114 virtioscsi_shutdown(dev);
117 // : virtio-scsi-send ( buf_addr buf_len is_read req_ptr rsp_ptr dev -- success)
118 PRIM(virtio_X2d_scsi_X2d_send)
119 void *dev = TOS.a; POP;
120 void *resp = TOS.a; POP;
121 void *req = TOS.a; POP;
122 int is_read = !!TOS.n; POP;
123 uint64_t blen = TOS.n; POP;
125 TOS.n = virtioscsi_send(dev, req, resp, is_read, buf, blen);
128 /******** virtio-net ********/
130 // : virtio-net-open ( dev -- false | [ driver true ] )
131 PRIM(virtio_X2d_net_X2d_open)
135 net_driver_t *net_driver = virtionet_open(dev);
138 TOS.u = (unsigned long)net_driver; PUSH;
145 // : virtio-net-close ( driver -- )
146 PRIM(virtio_X2d_net_X2d_close)
148 net_driver_t *driver = TOS.a; POP;
149 virtionet_close(driver);
153 // : virtio-net-read ( addr len -- actual )
154 PRIM(virtio_X2d_net_X2d_read)
156 int len = TOS.u; POP;
157 TOS.n = virtionet_read(TOS.a, len);
161 // : virtio-net-write ( addr len -- actual )
162 PRIM(virtio_X2d_net_X2d_write)
164 int len = TOS.u; POP;
165 TOS.n = virtionet_write(TOS.a, len);