X-Git-Url: http://git.cascardo.eti.br/?a=blobdiff_plain;f=lib%2Flacp.h;h=f35cff56a38ae80e696e5ad9f49e404c6f11aff7;hb=d0a46cb4608e632f5028034762f0adde2ce947a0;hp=293fc454d2f0d7ca1f9ae857ccf361949927b86a;hpb=bdebeece558fbeebb87c17b11a8468d88875037d;p=cascardo%2Fovs.git diff --git a/lib/lacp.h b/lib/lacp.h index 293fc454d..f35cff56a 100644 --- a/lib/lacp.h +++ b/lib/lacp.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011 Nicira Networks. + * Copyright (c) 2011 Nicira, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -23,12 +23,6 @@ /* LACP Protocol Implementation. */ -enum lacp_time { - LACP_TIME_FAST, /* LACP fast mode. */ - LACP_TIME_SLOW, /* LACP slow mode. */ - LACP_TIME_CUSTOM /* Nonstandard custom mode. */ -}; - enum lacp_status { LACP_NEGOTIATED, /* Successful LACP negotations. */ LACP_CONFIGURED, /* LACP is enabled but not negotiated. */ @@ -37,23 +31,23 @@ enum lacp_status { struct lacp_settings { char *name; /* Name (for debugging). */ - uint8_t id[ETH_ADDR_LEN]; /* System ID. Must be nonzero. */ + struct eth_addr id; /* System ID. Must be nonzero. */ uint16_t priority; /* System priority. */ bool active; /* Active or passive mode? */ - enum lacp_time lacp_time; /* Probe rate. */ - long long int custom_time; /* Probe interval if LACP_TIME_CUSTOM. */ - bool heartbeat; /* Heartbeat mode. */ + bool fast; /* Fast or slow probe interval. */ + bool fallback_ab_cfg; /* Fallback to BM_SLB on LACP failure. */ }; void lacp_init(void); struct lacp *lacp_create(void); -void lacp_destroy(struct lacp *); +void lacp_unref(struct lacp *); +struct lacp *lacp_ref(const struct lacp *); void lacp_configure(struct lacp *, const struct lacp_settings *); bool lacp_is_active(const struct lacp *); void lacp_process_packet(struct lacp *, const void *slave, - const struct ofpbuf *packet); + const struct dp_packet *packet); enum lacp_status lacp_status(const struct lacp *); struct lacp_slave_settings { @@ -68,7 +62,6 @@ void lacp_slave_register(struct lacp *, void *slave_, void lacp_slave_unregister(struct lacp *, const void *slave); void lacp_slave_carrier_changed(const struct lacp *, const void *slave); bool lacp_slave_may_enable(const struct lacp *, const void *slave); -uint16_t lacp_slave_get_port_id(const struct lacp *, const void *slave); bool lacp_slave_is_current(const struct lacp *, const void *slave_); /* Callback function for lacp_run() for sending a LACP PDU. */ @@ -77,4 +70,27 @@ typedef void lacp_send_pdu(void *slave, const void *pdu, size_t pdu_size); void lacp_run(struct lacp *, lacp_send_pdu *); void lacp_wait(struct lacp *); +struct lacp_slave_stats { + /* id */ + struct eth_addr dot3adAggPortActorSystemID; + struct eth_addr dot3adAggPortPartnerOperSystemID; + uint32_t dot3adAggPortAttachedAggID; + /* state */ + uint8_t dot3adAggPortActorAdminState; + uint8_t dot3adAggPortActorOperState; + uint8_t dot3adAggPortPartnerAdminState; + uint8_t dot3adAggPortPartnerOperState; + /* counters */ + uint32_t dot3adAggPortStatsLACPDUsRx; + /* uint32_t dot3adAggPortStatsMarkerPDUsRx; */ + /* uint32_t dot3adAggPortStatsMarkerResponsePDUsRx; */ + /* uint32_t dot3adAggPortStatsUnknownRx; */ + uint32_t dot3adAggPortStatsIllegalRx; + uint32_t dot3adAggPortStatsLACPDUsTx; + /* uint32_t dot3adAggPortStatsMarkerPDUsTx; */ + /* uint32_t dot3adAggPortStatsMarkerResponsePDUsTx; */ +}; + +bool lacp_get_slave_stats(const struct lacp *, const void *slave_, struct lacp_slave_stats *); + #endif /* lacp.h */