X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=KernelLand%2FModules%2FInterfaces%2FUDI%2Fudi_lib%2Fudi_nic.c;h=751a369ecb74300da69039ac8bdd039fb31d6237;hb=3fe3238f90216eeec97778e3ae91f462d27c60ac;hp=6bf636bb2b3e49ed71385a2c7c1a6d939385de51;hpb=de9c4d3d52751c9d66c61c062b74b02f80c31bf3;p=tpg%2Facess2.git diff --git a/KernelLand/Modules/Interfaces/UDI/udi_lib/udi_nic.c b/KernelLand/Modules/Interfaces/UDI/udi_lib/udi_nic.c index 6bf636bb..751a369e 100644 --- a/KernelLand/Modules/Interfaces/UDI/udi_lib/udi_nic.c +++ b/KernelLand/Modules/Interfaces/UDI/udi_lib/udi_nic.c @@ -1,10 +1,19 @@ /** - * \file physio.c - * \author John Hodge (thePowersGang) + * Acess2 UDI Layer + * - By John Hodge (thePowersGang) + * + * udi_lib/udi_nic.c + * - Network Interface metalanguage */ -#include +#define DEBUG 1 #include #include +#include // for EXPORT +#include + + +extern udi_mei_init_t udi_mei_info__nic; +#define udi_mei_info udi_mei_info__nic // === EXPORTS === EXPORT(udi_nd_bind_req); @@ -28,17 +37,35 @@ EXPORT(udi_nsr_rx_ind); EXPORT(udi_nsr_exp_rx_ind); EXPORT(udi_nd_rx_rdy); +// === GLOBALS === +tUDI_MetaLang cMetaLang_NIC = { + "udi_nic", + 8, + { + {0}, + {sizeof(udi_nic_cb_t), NULL}, + {sizeof(udi_nic_bind_cb_t), NULL}, + {sizeof(udi_nic_ctrl_cb_t), NULL}, + {sizeof(udi_nic_status_cb_t), NULL}, + {sizeof(udi_nic_info_cb_t), NULL}, + {sizeof(udi_nic_tx_cb_t), NULL}, + {sizeof(udi_nic_rx_cb_t), NULL}, + } +}; + // === CODE === // --- Control Ops --- -void udi_nd_bind_req(udi_nic_bind_cb_t *cb, udi_index_t tx_chan_index, udi_index_t rx_chan_index) -{ - UNIMPLEMENTED(); -} - -void udi_nsr_bind_ack(udi_nic_bind_cb_t *cb, udi_status_t status) -{ - UNIMPLEMENTED(); -} +UDI_MEI_STUBS(udi_nd_bind_req, udi_nic_bind_cb_t, + 2, + (tx_chan_index, rx_chan_index), + (udi_index_t, udi_index_t), + (UDI_VA_INDEX_T, UDI_VA_INDEX_T), + UDI_ND_CTRL_OPS_NUM, 1) +udi_layout_t _udi_nd_bind_req_marshal_layout[] = { UDI_DL_INDEX_T, UDI_DL_INDEX_T, UDI_DL_END }; +UDI_MEI_STUBS(udi_nsr_bind_ack, udi_nic_bind_cb_t, + 1, (status), (udi_status_t), (UDI_VA_STATUS_T), + UDI_NSR_CTRL_OPS_NUM, 1) +udi_layout_t _udi_nsr_bind_ack_marshal_layout[] = { UDI_DL_STATUS_T, UDI_DL_END }; void udi_nd_unbind_req(udi_nic_cb_t *cb) { @@ -107,18 +134,77 @@ void udi_nd_exp_tx_req(udi_nic_tx_cb_t *cb) } // --- RX --- -void udi_nsr_rx_ind(udi_nic_rx_cb_t *cb) -{ - UNIMPLEMENTED(); -} - -void udi_nsr_exp_rx_ind(udi_nic_rx_cb_t *cb) -{ - UNIMPLEMENTED(); -} - -void udi_nd_rx_rdy(udi_nic_rx_cb_t *cb) -{ - UNIMPLEMENTED(); -} - +UDI_MEI_STUBS(udi_nsr_rx_ind, udi_nic_rx_cb_t, 0, (), (), (), UDI_NSR_RX_OPS_NUM, 1) +udi_layout_t _udi_nsr_rx_ind_marshal_layout[] = { UDI_DL_END }; +UDI_MEI_STUBS(udi_nsr_exp_rx_ind, udi_nic_rx_cb_t, 0, (), (), (), UDI_NSR_RX_OPS_NUM, 2) +udi_layout_t _udi_nsr_exp_rx_ind_marshal_layout[] = { UDI_DL_END }; +UDI_MEI_STUBS(udi_nd_rx_rdy, udi_nic_rx_cb_t, 0, (), (), (), UDI_ND_RX_OPS_NUM, 1) +udi_layout_t _udi_nd_rx_rdy_marshal_layout[] = { UDI_DL_END }; + +#define UDI__OPS_NUM 0 +#define MEI_OPINFO(name,cat,flags,cbtype,rsp_ops,rsp_idx,err_ops,err_idx) \ + {#name, UDI_MEI_OPCAT_##cat,flags,UDI_##cbtype##_CB_NUM, \ + UDI_##rsp_ops##_OPS_NUM,rsp_idx,UDI_##err_ops##_OPS_NUM,err_idx, \ + name##_direct, name##_backend, _##cbtype##_cb_layout, _##name##_marshal_layout } + +udi_layout_t _NIC_BIND_cb_layout[] = { + UDI_DL_UBIT8_T, // media_type + UDI_DL_UBIT32_T, // min_pdu_size + UDI_DL_UBIT32_T, + UDI_DL_UBIT32_T, + UDI_DL_UBIT32_T, + UDI_DL_UBIT8_T, // max_perfect_multicast + UDI_DL_UBIT8_T, + UDI_DL_UBIT8_T, // mac_addr_len + UDI_DL_ARRAY, // mac_addr + UDI_NIC_MAC_ADDRESS_SIZE, + UDI_DL_UBIT8_T, + UDI_DL_END, + UDI_DL_END +}; +udi_layout_t _NIC_RX_cb_layout[] = { + UDI_DL_CB, // chain + UDI_DL_BUF, 0, 0, 0, // rx_buf + UDI_DL_UBIT8_T, // rx_status + UDI_DL_UBIT8_T, // addr_match + UDI_DL_UBIT8_T, // rx_valid + UDI_DL_END +}; + +udi_mei_op_template_t udi_mei_info__nic__nd_ctrl_ops[] = { + MEI_OPINFO(udi_nd_bind_req, REQ, 0, NIC_BIND, NSR_CTRL,1, ,0), + {0} +}; +udi_mei_op_template_t udi_mei_info__nic__nsr_ctrl_ops[] = { + MEI_OPINFO(udi_nsr_bind_ack, ACK, 0, NIC_BIND, ,0, ,0), + {0} +}; +udi_mei_op_template_t udi_mei_info__nic__nd_tx_ops[] = { + {0} +}; +udi_mei_op_template_t udi_mei_info__nic__nsr_tx_ops[] = { + {0} +}; +udi_mei_op_template_t udi_mei_info__nic__nd_rx_ops[] = { + MEI_OPINFO(udi_nd_rx_rdy, RDY, 0, NIC_RX, ,0, ,0), + {0} +}; +udi_mei_op_template_t udi_mei_info__nic__nsr_rx_ops[] = { + MEI_OPINFO(udi_nsr_rx_ind, IND, 0, NIC_RX, ND_RX,1, ,0), + MEI_OPINFO(udi_nsr_exp_rx_ind, IND, 0, NIC_RX, ND_RX,1, ,0), + {0} +}; + +udi_mei_ops_vec_template_t udi_mei_info__nic_ops[] = { + {UDI_ND_CTRL_OPS_NUM, UDI_MEI_REL_EXTERNAL|UDI_MEI_REL_BIND|UDI_MEI_REL_INITIATOR, udi_mei_info__nic__nd_ctrl_ops}, + {UDI_NSR_CTRL_OPS_NUM, UDI_MEI_REL_EXTERNAL|UDI_MEI_REL_BIND, udi_mei_info__nic__nsr_ctrl_ops}, + {UDI_ND_TX_OPS_NUM, UDI_MEI_REL_EXTERNAL|UDI_MEI_REL_INITIATOR, udi_mei_info__nic__nd_tx_ops}, + {UDI_NSR_TX_OPS_NUM, UDI_MEI_REL_EXTERNAL, udi_mei_info__nic__nsr_tx_ops}, + {UDI_ND_RX_OPS_NUM, UDI_MEI_REL_EXTERNAL|UDI_MEI_REL_INITIATOR, udi_mei_info__nic__nd_rx_ops}, + {UDI_NSR_RX_OPS_NUM, UDI_MEI_REL_EXTERNAL, udi_mei_info__nic__nsr_rx_ops}, + {0} +}; +udi_mei_init_t udi_mei_info__nic = { + udi_mei_info__nic_ops, + NULL +};