2014-03-25 20:39:02 +01:00
|
|
|
/*
|
|
|
|
* SecY Operations
|
|
|
|
* Copyright (c) 2013, Qualcomm Atheros, Inc.
|
|
|
|
*
|
|
|
|
* This software may be distributed under the terms of the BSD license.
|
|
|
|
* See README for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef IEEE802_1X_SECY_OPS_H
|
|
|
|
#define IEEE802_1X_SECY_OPS_H
|
|
|
|
|
|
|
|
#include "common/defs.h"
|
|
|
|
#include "common/ieee802_1x_defs.h"
|
|
|
|
|
|
|
|
struct ieee802_1x_kay_conf;
|
|
|
|
|
|
|
|
int secy_init_macsec(struct ieee802_1x_kay *kay);
|
|
|
|
int secy_deinit_macsec(struct ieee802_1x_kay *kay);
|
|
|
|
|
|
|
|
/****** CP -> SecY ******/
|
|
|
|
int secy_cp_control_validate_frames(struct ieee802_1x_kay *kay,
|
|
|
|
enum validate_frames vf);
|
|
|
|
int secy_cp_control_protect_frames(struct ieee802_1x_kay *kay, Boolean flag);
|
2016-11-02 16:38:38 +01:00
|
|
|
int secy_cp_control_encrypt(struct ieee802_1x_kay *kay, Boolean enabled);
|
2014-03-25 20:39:02 +01:00
|
|
|
int secy_cp_control_replay(struct ieee802_1x_kay *kay, Boolean flag, u32 win);
|
2016-08-12 15:07:35 +02:00
|
|
|
int secy_cp_control_current_cipher_suite(struct ieee802_1x_kay *kay, u64 cs);
|
2014-03-25 20:39:02 +01:00
|
|
|
int secy_cp_control_confidentiality_offset(struct ieee802_1x_kay *kay,
|
|
|
|
enum confidentiality_offset co);
|
|
|
|
int secy_cp_control_enable_port(struct ieee802_1x_kay *kay, Boolean flag);
|
|
|
|
|
|
|
|
/****** KaY -> SecY *******/
|
2016-10-07 12:08:12 +02:00
|
|
|
int secy_get_capability(struct ieee802_1x_kay *kay, enum macsec_cap *cap);
|
2014-03-25 20:39:02 +01:00
|
|
|
int secy_get_receive_lowest_pn(struct ieee802_1x_kay *kay,
|
|
|
|
struct receive_sa *rxsa);
|
|
|
|
int secy_get_transmit_next_pn(struct ieee802_1x_kay *kay,
|
|
|
|
struct transmit_sa *txsa);
|
|
|
|
int secy_set_transmit_next_pn(struct ieee802_1x_kay *kay,
|
|
|
|
struct transmit_sa *txsa);
|
2018-02-20 20:28:39 +01:00
|
|
|
int secy_set_receive_lowest_pn(struct ieee802_1x_kay *kay,
|
|
|
|
struct receive_sa *txsa);
|
2014-03-25 20:39:02 +01:00
|
|
|
int secy_create_receive_sc(struct ieee802_1x_kay *kay, struct receive_sc *rxsc);
|
|
|
|
int secy_delete_receive_sc(struct ieee802_1x_kay *kay, struct receive_sc *rxsc);
|
|
|
|
int secy_create_receive_sa(struct ieee802_1x_kay *kay, struct receive_sa *rxsa);
|
2016-10-21 14:45:28 +02:00
|
|
|
int secy_delete_receive_sa(struct ieee802_1x_kay *kay, struct receive_sa *rxsa);
|
2014-03-25 20:39:02 +01:00
|
|
|
int secy_enable_receive_sa(struct ieee802_1x_kay *kay, struct receive_sa *rxsa);
|
|
|
|
int secy_disable_receive_sa(struct ieee802_1x_kay *kay,
|
|
|
|
struct receive_sa *rxsa);
|
|
|
|
|
|
|
|
int secy_create_transmit_sc(struct ieee802_1x_kay *kay,
|
|
|
|
struct transmit_sc *txsc);
|
|
|
|
int secy_delete_transmit_sc(struct ieee802_1x_kay *kay,
|
|
|
|
struct transmit_sc *txsc);
|
|
|
|
int secy_create_transmit_sa(struct ieee802_1x_kay *kay,
|
|
|
|
struct transmit_sa *txsa);
|
2016-10-21 14:45:28 +02:00
|
|
|
int secy_delete_transmit_sa(struct ieee802_1x_kay *kay,
|
|
|
|
struct transmit_sa *txsa);
|
2014-03-25 20:39:02 +01:00
|
|
|
int secy_enable_transmit_sa(struct ieee802_1x_kay *kay,
|
|
|
|
struct transmit_sa *txsa);
|
|
|
|
int secy_disable_transmit_sa(struct ieee802_1x_kay *kay,
|
|
|
|
struct transmit_sa *txsa);
|
|
|
|
|
|
|
|
#endif /* IEEE802_1X_SECY_OPS_H */
|