summaryrefslogtreecommitdiff
path: root/usr/src/uts/common/sys/ddi_ufm_impl.h
blob: 8570f7f11e9da2726945428511152aabf3936408 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/*
 * This file and its contents are supplied under the terms of the
 * Common Development and Distribution License ("CDDL"), version 1.0.
 * You may only use this file in accordance with the terms of version
 * 1.0 of the CDDL.
 *
 * A full copy of the text of the CDDL should have accompanied this
 * source.  A copy of the CDDL is also available via the Internet at
 * http://www.illumos.org/license/CDDL.
 */

/*
 * Copyright 2019 Joyent, Inc.
 * Copyright 2020 Oxide Computer Company
 */

#ifndef _SYS_DDI_UFM_IMPL_H
#define	_SYS_DDI_UFM_IMPL_H

#ifdef __cplusplus
extern "C" {
#endif

#include <sys/avl.h>
#include <sys/ddi_ufm.h>
#include <sys/mutex.h>
#include <sys/nvpair.h>
#include <sys/types.h>

typedef enum {
	DDI_UFM_STATE_INIT		= 1 << 0,
	DDI_UFM_STATE_READY		= 1 << 1,
	DDI_UFM_STATE_SHUTTING_DOWN	= 1 << 2
} ddi_ufm_state_t;

/* private interface for startup_ddi() */
void ufm_init();

/* private interfaces for ufm driver */
struct ddi_ufm_handle *ufm_find(const char *);
int ufm_cache_fill(struct ddi_ufm_handle *ufmh);
int ufm_read_img(ddi_ufm_handle_t *, uint_t, uint_t, uint64_t, uint64_t,
    uintptr_t, uint64_t *, int);

struct ddi_ufm_slot {
	uint_t			ufms_slotno;
	char			*ufms_version;
	ddi_ufm_attr_t		ufms_attrs;
	uint64_t		ufms_imgsize;
	nvlist_t		*ufms_misc;
};

struct ddi_ufm_image {
	uint_t			ufmi_imageno;
	char			*ufmi_desc;
	nvlist_t		*ufmi_misc;
	struct ddi_ufm_slot	*ufmi_slots;
	uint_t			ufmi_nslots;
};

struct ddi_ufm_handle {
	/*
	 * The following fields get filled in when a UFM-aware driver calls
	 * ddi_ufm_init(9E).  They remain valid until the driver calls
	 * ddi_ufm_fini(9E).  You can test for validity of these fields by
	 * checking if the DDI_UFM_STATE_INIT flag is set in ufmh_state.
	 */
	kmutex_t		ufmh_lock;
	char			ufmh_devpath[MAXPATHLEN];
	ddi_ufm_ops_t		*ufmh_ops;
	void			*ufmh_arg;
	uint_t			ufmh_state;
	uint_t			ufmh_version;
	/*
	 * The following four fields represent lazily cached UFM data
	 * retrieved from a UFM-aware driver.  If ufmh_report is non-NULL
	 * then all four of these fields will contain valid data.
	 */
	struct ddi_ufm_image	*ufmh_images;
	uint_t			ufmh_nimages;
	ddi_ufm_cap_t		ufmh_caps;
	nvlist_t		*ufmh_report;

	avl_node_t		ufmh_link;
};

#ifdef __cplusplus
}
#endif

#endif	/* _SYS_DDI_UFM_IMPL_H */