cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

target_core_alua.h (6125B)


      1/* SPDX-License-Identifier: GPL-2.0 */
      2#ifndef TARGET_CORE_ALUA_H
      3#define TARGET_CORE_ALUA_H
      4
      5#include <target/target_core_base.h>
      6
      7/*
      8 * INQUIRY response data, TPGS Field
      9 *
     10 * from spc4r17 section 6.4.2 Table 135
     11 */
     12#define TPGS_NO_ALUA				0x00
     13#define TPGS_IMPLICIT_ALUA			0x10
     14#define TPGS_EXPLICIT_ALUA			0x20
     15
     16/*
     17 * ASYMMETRIC ACCESS STATE field
     18 *
     19 * from spc4r36j section 6.37 Table 307
     20 */
     21#define ALUA_ACCESS_STATE_ACTIVE_OPTIMIZED	0x0
     22#define ALUA_ACCESS_STATE_ACTIVE_NON_OPTIMIZED	0x1
     23#define ALUA_ACCESS_STATE_STANDBY		0x2
     24#define ALUA_ACCESS_STATE_UNAVAILABLE		0x3
     25#define ALUA_ACCESS_STATE_LBA_DEPENDENT		0x4
     26#define ALUA_ACCESS_STATE_OFFLINE		0xe
     27#define ALUA_ACCESS_STATE_TRANSITION		0xf
     28
     29/*
     30 * from spc4r36j section 6.37 Table 306
     31 */
     32#define ALUA_T_SUP		0x80
     33#define ALUA_O_SUP		0x40
     34#define ALUA_LBD_SUP		0x10
     35#define ALUA_U_SUP		0x08
     36#define ALUA_S_SUP		0x04
     37#define ALUA_AN_SUP		0x02
     38#define ALUA_AO_SUP		0x01
     39
     40/*
     41 * REPORT_TARGET_PORT_GROUP STATUS CODE
     42 *
     43 * from spc4r17 section 6.27 Table 246
     44 */
     45#define ALUA_STATUS_NONE				0x00
     46#define ALUA_STATUS_ALTERED_BY_EXPLICIT_STPG		0x01
     47#define ALUA_STATUS_ALTERED_BY_IMPLICIT_ALUA		0x02
     48
     49/*
     50 * From spc4r17, Table D.1: ASC and ASCQ Assignement
     51 */
     52#define ASCQ_04H_ALUA_STATE_TRANSITION			0x0a
     53#define ASCQ_04H_ALUA_TG_PT_STANDBY			0x0b
     54#define ASCQ_04H_ALUA_TG_PT_UNAVAILABLE			0x0c
     55#define ASCQ_04H_ALUA_OFFLINE				0x12
     56
     57/*
     58 * Used as the default for Active/NonOptimized delay (in milliseconds)
     59 * This can also be changed via configfs on a per target port group basis..
     60 */
     61#define ALUA_DEFAULT_NONOP_DELAY_MSECS			100
     62#define ALUA_MAX_NONOP_DELAY_MSECS			10000 /* 10 seconds */
     63/*
     64 * Used for implicit and explicit ALUA transitional delay, that is disabled
     65 * by default, and is intended to be used for debugging client side ALUA code.
     66 */
     67#define ALUA_DEFAULT_TRANS_DELAY_MSECS			0
     68#define ALUA_MAX_TRANS_DELAY_MSECS			30000 /* 30 seconds */
     69/*
     70 * Used for the recommended application client implicit transition timeout
     71 * in seconds, returned by the REPORT_TARGET_PORT_GROUPS w/ extended header.
     72 */
     73#define ALUA_DEFAULT_IMPLICIT_TRANS_SECS			0
     74#define ALUA_MAX_IMPLICIT_TRANS_SECS			255
     75
     76/* Used by core_alua_update_tpg_(primary,secondary)_metadata */
     77#define ALUA_MD_BUF_LEN					1024
     78
     79extern struct kmem_cache *t10_alua_lu_gp_cache;
     80extern struct kmem_cache *t10_alua_lu_gp_mem_cache;
     81extern struct kmem_cache *t10_alua_tg_pt_gp_cache;
     82extern struct kmem_cache *t10_alua_lba_map_cache;
     83extern struct kmem_cache *t10_alua_lba_map_mem_cache;
     84
     85extern sense_reason_t target_emulate_report_target_port_groups(struct se_cmd *);
     86extern sense_reason_t target_emulate_set_target_port_groups(struct se_cmd *);
     87extern sense_reason_t target_emulate_report_referrals(struct se_cmd *);
     88extern int core_alua_check_nonop_delay(struct se_cmd *);
     89extern int core_alua_do_port_transition(struct t10_alua_tg_pt_gp *,
     90				struct se_device *, struct se_lun *,
     91				struct se_node_acl *, int, int);
     92extern char *core_alua_dump_status(int);
     93extern struct t10_alua_lba_map *core_alua_allocate_lba_map(
     94				struct list_head *, u64, u64);
     95extern int core_alua_allocate_lba_map_mem(struct t10_alua_lba_map *, int, int);
     96extern void core_alua_free_lba_map(struct list_head *);
     97extern void core_alua_set_lba_map(struct se_device *, struct list_head *,
     98				int, int);
     99extern struct t10_alua_lu_gp *core_alua_allocate_lu_gp(const char *, int);
    100extern int core_alua_set_lu_gp_id(struct t10_alua_lu_gp *, u16);
    101extern void core_alua_free_lu_gp(struct t10_alua_lu_gp *);
    102extern void core_alua_free_lu_gp_mem(struct se_device *);
    103extern struct t10_alua_lu_gp *core_alua_get_lu_gp_by_name(const char *);
    104extern void core_alua_put_lu_gp_from_name(struct t10_alua_lu_gp *);
    105extern void __core_alua_attach_lu_gp_mem(struct t10_alua_lu_gp_member *,
    106					struct t10_alua_lu_gp *);
    107extern void __core_alua_drop_lu_gp_mem(struct t10_alua_lu_gp_member *,
    108					struct t10_alua_lu_gp *);
    109extern void core_alua_drop_lu_gp_dev(struct se_device *);
    110extern struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp(
    111			struct se_device *, const char *, int);
    112extern int core_alua_set_tg_pt_gp_id(struct t10_alua_tg_pt_gp *, u16);
    113extern void core_alua_free_tg_pt_gp(struct t10_alua_tg_pt_gp *);
    114extern void target_detach_tg_pt_gp(struct se_lun *);
    115extern void target_attach_tg_pt_gp(struct se_lun *, struct t10_alua_tg_pt_gp *);
    116extern ssize_t core_alua_show_tg_pt_gp_info(struct se_lun *, char *);
    117extern ssize_t core_alua_store_tg_pt_gp_info(struct se_lun *, const char *,
    118						size_t);
    119extern ssize_t core_alua_show_access_type(struct t10_alua_tg_pt_gp *, char *);
    120extern ssize_t core_alua_store_access_type(struct t10_alua_tg_pt_gp *,
    121					const char *, size_t);
    122extern ssize_t core_alua_show_nonop_delay_msecs(struct t10_alua_tg_pt_gp *,
    123						char *);
    124extern ssize_t core_alua_store_nonop_delay_msecs(struct t10_alua_tg_pt_gp *,
    125					const char *, size_t);
    126extern ssize_t core_alua_show_trans_delay_msecs(struct t10_alua_tg_pt_gp *,
    127					char *);
    128extern ssize_t core_alua_store_trans_delay_msecs(struct t10_alua_tg_pt_gp *,
    129					const char *, size_t);
    130extern ssize_t core_alua_show_implicit_trans_secs(struct t10_alua_tg_pt_gp *,
    131					char *);
    132extern ssize_t core_alua_store_implicit_trans_secs(struct t10_alua_tg_pt_gp *,
    133					const char *, size_t);
    134extern ssize_t core_alua_show_preferred_bit(struct t10_alua_tg_pt_gp *,
    135					char *);
    136extern ssize_t core_alua_store_preferred_bit(struct t10_alua_tg_pt_gp *,
    137					const char *, size_t);
    138extern ssize_t core_alua_show_offline_bit(struct se_lun *, char *);
    139extern ssize_t core_alua_store_offline_bit(struct se_lun *, const char *,
    140					size_t);
    141extern ssize_t core_alua_show_secondary_status(struct se_lun *, char *);
    142extern ssize_t core_alua_store_secondary_status(struct se_lun *,
    143					const char *, size_t);
    144extern ssize_t core_alua_show_secondary_write_metadata(struct se_lun *,
    145					char *);
    146extern ssize_t core_alua_store_secondary_write_metadata(struct se_lun *,
    147					const char *, size_t);
    148extern int core_setup_alua(struct se_device *);
    149extern sense_reason_t target_alua_state_check(struct se_cmd *cmd);
    150
    151#endif /* TARGET_CORE_ALUA_H */