b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * CDDL HEADER START
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * The contents of this file are subject to the terms of the
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * Common Development and Distribution License (the "License").
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * You may not use this file except in compliance with the License.
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * or http://www.opensolaris.org/os/licensing.
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * See the License for the specific language governing permissions
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * and limitations under the License.
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * When distributing Covered Code, include this CDDL HEADER in each
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * If applicable, add the following below this CDDL HEADER, with the
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * fields enclosed by brackets "[]" replaced with your own identifying
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * information: Portions Copyright [yyyy] [name of copyright owner]
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * CDDL HEADER END
327151705b7439cb7ab35c370f682cac7ef9523aCathy Zhou * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaistatic dladm_status_t dladm_simnet_persist_conf(dladm_handle_t, const char *,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* New simnet instance creation */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaii_dladm_create_simnet(dladm_handle_t handle, dladm_simnet_attr_t *attrp)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if (attrp->sna_mac_len > 0 && attrp->sna_mac_len <= MAXMACADDRLEN) {
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai bcopy(attrp->sna_mac_addr, ioc.sic_mac_addr, ioc.sic_mac_len);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai rc = ioctl(dladm_dld_fd(handle), SIMNET_IOC_CREATE, &ioc);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai bcopy(ioc.sic_mac_addr, attrp->sna_mac_addr, MAXMACADDRLEN);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Modify existing simnet instance */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaii_dladm_modify_simnet(dladm_handle_t handle, dladm_simnet_attr_t *attrp)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai ioc.sim_peer_link_id = attrp->sna_peer_link_id;
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai rc = ioctl(dladm_dld_fd(handle), SIMNET_IOC_MODIFY, &ioc);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Delete simnet instance */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaii_dladm_delete_simnet(dladm_handle_t handle, dladm_simnet_attr_t *attrp)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai rc = ioctl(dladm_dld_fd(handle), SIMNET_IOC_DELETE, &ioc);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Retrieve simnet instance information */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaii_dladm_get_simnet_info(dladm_handle_t handle, dladm_simnet_attr_t *attrp)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai rc = ioctl(dladm_dld_fd(handle), SIMNET_IOC_INFO, &ioc);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai bcopy(ioc.sii_mac_addr, attrp->sna_mac_addr, MAXMACADDRLEN);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai attrp->sna_peer_link_id = ioc.sii_peer_link_id;
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Retrieve simnet configuratin */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaii_dladm_get_simnet_info_persist(dladm_handle_t handle,
327151705b7439cb7ab35c370f682cac7ef9523aCathy Zhou if ((status = dladm_getsnap_conf(handle, attrp->sna_link_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = dladm_get_conf_field(handle, conf, FSIMNETTYPE, &u64,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = dladm_get_conf_field(handle, conf, FMADDRLEN, &u64,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = dladm_get_conf_field(handle, conf, FMACADDR, macstr,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_aggr_str2macaddr(macstr, &mac_fixed, attrp->sna_mac_addr);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* Peer field is optional and only set when peer is attached */
2b24ab6b3865caeede9eeb9db6b83e1d89dcd1eaSebastien Roy if (dladm_get_conf_field(handle, conf, FSIMNETPEER, simnetpeer,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai attrp->sna_peer_link_id = DATALINK_INVALID_LINKID;
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaidladm_simnet_create(dladm_handle_t handle, const char *simnetname,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai flags &= (DLADM_OPT_ACTIVE | DLADM_OPT_PERSIST);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((status = dladm_create_datalink_id(handle, simnetname,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_create_simnet(handle, &attr);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = dladm_simnet_persist_conf(handle, simnetname, &attr);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) i_dladm_delete_simnet(handle, &attr);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_set_linkprop(handle, simnet_id, NULL, NULL, 0, flags);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_destroy_datalink_id(handle, simnet_id, flags);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Update existing simnet configuration */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaii_dladm_simnet_update_conf(dladm_handle_t handle, datalink_id_t simnet_id,
327151705b7439cb7ab35c370f682cac7ef9523aCathy Zhou status = dladm_open_conf(handle, simnet_id, &conf);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* First clear previous peer if any in configuration */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_unset_conf_field(handle, conf, FSIMNETPEER);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if (peer_simnet_id != DATALINK_INVALID_LINKID) {
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((status = dladm_datalink_id2info(handle,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = dladm_set_conf_field(handle, conf,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Modify attached simnet peer */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaidladm_simnet_modify(dladm_handle_t handle, datalink_id_t simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai datalink_id_t peer_simnet_id, uint32_t flags)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((dladm_datalink_id2info(handle, simnet_id, &linkflags, &class,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if (peer_simnet_id != DATALINK_INVALID_LINKID) {
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if (dladm_datalink_id2info(handle, peer_simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai &peerlinkflags, &class, NULL, NULL, 0) != DLADM_STATUS_OK)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* Check to ensure the peer link has identical flags */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* Retrieve previous attrs before modification */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((status = dladm_simnet_info(handle, simnet_id, &prevattr,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_modify_simnet(handle, &attr);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((status != DLADM_STATUS_OK) || !(flags & DLADM_OPT_PERSIST))
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* First we clear link's existing peer field in config */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_simnet_update_conf(handle, simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* Clear the previous peer link's existing peer field in config */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if (prevattr.sna_peer_link_id != DATALINK_INVALID_LINKID) {
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_simnet_update_conf(handle,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai prevattr.sna_peer_link_id, DATALINK_INVALID_LINKID);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* Update the configuration in both simnets with any new peer link */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if (peer_simnet_id != DATALINK_INVALID_LINKID) {
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_simnet_update_conf(handle, simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_simnet_update_conf(handle,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaidladm_simnet_delete(dladm_handle_t handle, datalink_id_t simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((dladm_datalink_id2info(handle, simnet_id, NULL, &class,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* Check current simnet attributes before deletion */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai flags &= (DLADM_OPT_ACTIVE | DLADM_OPT_PERSIST);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((status = dladm_simnet_info(handle, simnet_id, &prevattr,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_delete_simnet(handle, &attr);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_set_linkprop(handle, simnet_id, NULL,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_destroy_datalink_id(handle, simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai } else if (status != DLADM_STATUS_NOTFOUND) {
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_destroy_datalink_id(handle, simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai /* Update any attached peer configuration */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if (prevattr.sna_peer_link_id != DATALINK_INVALID_LINKID)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_simnet_update_conf(handle,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai prevattr.sna_peer_link_id, DATALINK_INVALID_LINKID);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Retrieve simnet information either active or from configuration */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaidladm_simnet_info(dladm_handle_t handle, datalink_id_t simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai dladm_simnet_attr_t *attrp, uint32_t flags)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((dladm_datalink_id2info(handle, simnet_id, NULL, &class,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_get_simnet_info(handle, attrp);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * If no active simnet found then return any simnet
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * from stored config if requested.
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai return (i_dladm_get_simnet_info_persist(handle, attrp));
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai return (i_dladm_get_simnet_info_persist(handle, attrp));
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Bring up simnet from stored configuration */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaii_dladm_simnet_up(dladm_handle_t handle, datalink_id_t simnet_id, void *arg)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = dladm_simnet_info(handle, simnet_id, &attr,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_create_simnet(handle, &attr);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * When bringing up check if the peer link is available, if it
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai * is then modify the simnet and attach the peer link.
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((attr.sna_peer_link_id != DATALINK_INVALID_LINKID) &&
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (dladm_simnet_info(handle, attr.sna_peer_link_id, &peer_attr,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = i_dladm_modify_simnet(handle, &attr);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((status = dladm_up_datalink_id(handle, simnet_id)) !=
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_simnet_delete(handle, simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Bring up simnet instance(s) from configuration */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaidladm_simnet_up(dladm_handle_t handle, datalink_id_t simnet_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) dladm_walk_datalink_id(i_dladm_simnet_up, handle,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai &status, DATALINK_CLASS_SIMNET, DATALINK_ANY_MEDIATYPE,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai (void) i_dladm_simnet_up(handle, simnet_id, &status);
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai/* Store simnet configuration */
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavaidladm_simnet_persist_conf(dladm_handle_t handle, const char *name,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai if ((status = dladm_create_conf(handle, name, attrp->sna_link_id,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai DATALINK_CLASS_SIMNET, attrp->sna_type, &conf)) != DLADM_STATUS_OK)
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = dladm_set_conf_field(handle, conf, FMACADDR,
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai DLADM_TYPE_STR, dladm_aggr_macaddr2str(attrp->sna_mac_addr, mstr));
b509e89b2befbaa42939abad9da1d7f5a8c6aaaeRishi Srivatsavai status = dladm_set_conf_field(handle, conf, FSIMNETTYPE,