hpi_pfc.h revision 3dec9fcdd56adf1b4a563137b4915c8f2d83b881
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * CDDL HEADER START
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * The contents of this file are subject to the terms of the
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * Common Development and Distribution License (the "License").
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * You may not use this file except in compliance with the License.
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * See the License for the specific language governing permissions
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * and limitations under the License.
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * When distributing Covered Code, include this CDDL HEADER in each
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * If applicable, add the following below this CDDL HEADER, with the
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * fields enclosed by brackets "[]" replaced with your own identifying
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * information: Portions Copyright [yyyy] [name of copyright owner]
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * CDDL HEADER END
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * Use is subject to license terms.
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs#pragma ident "%Z%%M% %I% %E% SMI"
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qsextern "C" {
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qstypedef enum _tcam_op {
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * HPI PFC ERROR Codes
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs#define HPI_PFC_RESET_ERROR (HPI_PFC_ERROR | HPI_GEN_PFC | RESET_FAILED)
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs/* have only 0xc, 0xd, 0xe and 0xf left for sw error codes */
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs ((((vlan_id_t)(vlan_id / PFC_N_VLAN_MEMBERS)) * 8) + PFC_VLAN_TABLE)
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs ((slot * PFC_L2_CLASS_CONFIG_STEP) + PFC_L2_CLASS_CONFIG)
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs (((slot - TCAM_CLASS_TCP_IPV4) * PFC_L3_CLASS_CONFIG_STEP) + \
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC Control Register Functions
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcam_enable(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_l2_hash(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcp_cksum(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_default_dma(hpi_handle_t, uint32_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_mac_addr_enable(hpi_handle_t, uint32_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_mac_addr_disable(hpi_handle_t, uint32_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_force_csum(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC vlan Functions
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_cfg_vlan_table_entry_clear(hpi_handle_t, vlan_id_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_cfg_vlan_table_entry_set(hpi_handle_t, vlan_id_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_cfg_vlan_control_set(hpi_handle_t, boolean_t,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC Mac Address Functions
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_mac_address(hpi_handle_t, uint32_t, uint64_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_clear_mac_address(hpi_handle_t, uint32_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_clear_multicast_hash_table(hpi_handle_t, uint32_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_multicast_hash_table(hpi_handle_t, uint32_t,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC L2 and L3 Config Functions.
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_l2_class_slot(hpi_handle_t, uint16_t, boolean_t, int);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_get_l3_class_config(hpi_handle_t handle, tcam_class_t slot,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_l3_class_config(hpi_handle_t handle, tcam_class_t slot,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC TCAM Functions
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_tcam_entry_invalidate(hpi_handle_t, uint32_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_tcam_entry_write(hpi_handle_t, uint32_t,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_tcam_entry_read(hpi_handle_t, uint32_t,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_tcam_asc_ram_entry_read(hpi_handle_t handle,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_tcam_asc_ram_entry_write(hpi_handle_t handle,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC TCP Control
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcp_control_discard(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcp_control_fin(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcp_control_syn(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcp_control_rst(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcp_control_psh(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcp_control_ack(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_tcp_control_urg(hpi_handle_t, boolean_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC Hash Seed Value
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_hash_seed_value(hpi_handle_t, uint32_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC Interrupt Management Functions
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_get_interrupt_status(hpi_handle_t, pfc_int_status_t *);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_clear_interrupt_status(hpi_handle_t);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_interrupt_mask(hpi_handle_t, boolean_t,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs * PFC Packet Logs
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_get_drop_log(hpi_handle_t, pfc_drop_log_t *);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_set_drop_log_mask(hpi_handle_t, boolean_t,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_get_bad_csum_counter(hpi_handle_t, uint64_t *);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_get_drop_counter(hpi_handle_t, uint64_t *);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_get_number_mac_addrs(hpi_handle_t handle,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_mac_addr_get_i(hpi_handle_t handle, uint8_t *data,
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qshpi_status_t hpi_pfc_num_macs_get(hpi_handle_t handle, uint8_t *data);
3dec9fcdd56adf1b4a563137b4915c8f2d83b881qs#endif /* !_HPI_PFC_H */