174fe6c29SRuslan Bukin /*
2*85f87cf4SRuslan Bukin * Copyright (c) 2013-2019, Intel Corporation
374fe6c29SRuslan Bukin *
474fe6c29SRuslan Bukin * Redistribution and use in source and binary forms, with or without
574fe6c29SRuslan Bukin * modification, are permitted provided that the following conditions are met:
674fe6c29SRuslan Bukin *
774fe6c29SRuslan Bukin * * Redistributions of source code must retain the above copyright notice,
874fe6c29SRuslan Bukin * this list of conditions and the following disclaimer.
974fe6c29SRuslan Bukin * * Redistributions in binary form must reproduce the above copyright notice,
1074fe6c29SRuslan Bukin * this list of conditions and the following disclaimer in the documentation
1174fe6c29SRuslan Bukin * and/or other materials provided with the distribution.
1274fe6c29SRuslan Bukin * * Neither the name of Intel Corporation nor the names of its contributors
1374fe6c29SRuslan Bukin * may be used to endorse or promote products derived from this software
1474fe6c29SRuslan Bukin * without specific prior written permission.
1574fe6c29SRuslan Bukin *
1674fe6c29SRuslan Bukin * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
1774fe6c29SRuslan Bukin * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1874fe6c29SRuslan Bukin * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1974fe6c29SRuslan Bukin * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
2074fe6c29SRuslan Bukin * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
2174fe6c29SRuslan Bukin * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
2274fe6c29SRuslan Bukin * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
2374fe6c29SRuslan Bukin * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
2474fe6c29SRuslan Bukin * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
2574fe6c29SRuslan Bukin * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
2674fe6c29SRuslan Bukin * POSSIBILITY OF SUCH DAMAGE.
2774fe6c29SRuslan Bukin */
2874fe6c29SRuslan Bukin
2974fe6c29SRuslan Bukin #include "pt_decoder_function.h"
3074fe6c29SRuslan Bukin #include "pt_packet_decoder.h"
3174fe6c29SRuslan Bukin #include "pt_query_decoder.h"
3274fe6c29SRuslan Bukin #include "pt_opcodes.h"
3374fe6c29SRuslan Bukin
3474fe6c29SRuslan Bukin #include "intel-pt.h"
3574fe6c29SRuslan Bukin
3674fe6c29SRuslan Bukin
3774fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_unknown = {
3874fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_unknown,
3974fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_unknown,
4074fe6c29SRuslan Bukin /* .header = */ pt_qry_decode_unknown,
4174fe6c29SRuslan Bukin /* .flags = */ pdff_unknown
4274fe6c29SRuslan Bukin };
4374fe6c29SRuslan Bukin
4474fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_pad = {
4574fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_pad,
4674fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_pad,
4774fe6c29SRuslan Bukin /* .header = */ pt_qry_decode_pad,
4874fe6c29SRuslan Bukin /* .flags = */ pdff_pad
4974fe6c29SRuslan Bukin };
5074fe6c29SRuslan Bukin
5174fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_psb = {
5274fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_psb,
5374fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_psb,
5474fe6c29SRuslan Bukin /* .header = */ NULL,
5574fe6c29SRuslan Bukin /* .flags = */ 0
5674fe6c29SRuslan Bukin };
5774fe6c29SRuslan Bukin
5874fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_tip = {
5974fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_tip,
6074fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_tip,
6174fe6c29SRuslan Bukin /* .header = */ NULL,
6274fe6c29SRuslan Bukin /* .flags = */ pdff_tip
6374fe6c29SRuslan Bukin };
6474fe6c29SRuslan Bukin
6574fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_tnt_8 = {
6674fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_tnt_8,
6774fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_tnt_8,
6874fe6c29SRuslan Bukin /* .header = */ NULL,
6974fe6c29SRuslan Bukin /* .flags = */ pdff_tnt
7074fe6c29SRuslan Bukin };
7174fe6c29SRuslan Bukin
7274fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_tnt_64 = {
7374fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_tnt_64,
7474fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_tnt_64,
7574fe6c29SRuslan Bukin /* .header = */ NULL,
7674fe6c29SRuslan Bukin /* .flags = */ pdff_tnt
7774fe6c29SRuslan Bukin };
7874fe6c29SRuslan Bukin
7974fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_tip_pge = {
8074fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_tip_pge,
8174fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_tip_pge,
8274fe6c29SRuslan Bukin /* .header = */ NULL,
8374fe6c29SRuslan Bukin /* .flags = */ pdff_event
8474fe6c29SRuslan Bukin };
8574fe6c29SRuslan Bukin
8674fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_tip_pgd = {
8774fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_tip_pgd,
8874fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_tip_pgd,
8974fe6c29SRuslan Bukin /* .header = */ NULL,
9074fe6c29SRuslan Bukin /* .flags = */ pdff_event
9174fe6c29SRuslan Bukin };
9274fe6c29SRuslan Bukin
9374fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_fup = {
9474fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_fup,
9574fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_fup,
9674fe6c29SRuslan Bukin /* .header = */ pt_qry_header_fup,
9774fe6c29SRuslan Bukin /* .flags = */ pdff_fup
9874fe6c29SRuslan Bukin };
9974fe6c29SRuslan Bukin
10074fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_pip = {
10174fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_pip,
10274fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_pip,
10374fe6c29SRuslan Bukin /* .header = */ pt_qry_header_pip,
10474fe6c29SRuslan Bukin /* .flags = */ pdff_event
10574fe6c29SRuslan Bukin };
10674fe6c29SRuslan Bukin
10774fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_ovf = {
10874fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_ovf,
10974fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_ovf,
11074fe6c29SRuslan Bukin /* .header = */ NULL,
11174fe6c29SRuslan Bukin /* .flags = */ pdff_psbend | pdff_event
11274fe6c29SRuslan Bukin };
11374fe6c29SRuslan Bukin
11474fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_mode = {
11574fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_mode,
11674fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_mode,
11774fe6c29SRuslan Bukin /* .header = */ pt_qry_header_mode,
11874fe6c29SRuslan Bukin /* .flags = */ pdff_event
11974fe6c29SRuslan Bukin };
12074fe6c29SRuslan Bukin
12174fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_psbend = {
12274fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_psbend,
12374fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_psbend,
12474fe6c29SRuslan Bukin /* .header = */ NULL,
12574fe6c29SRuslan Bukin /* .flags = */ pdff_psbend
12674fe6c29SRuslan Bukin };
12774fe6c29SRuslan Bukin
12874fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_tsc = {
12974fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_tsc,
13074fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_tsc,
13174fe6c29SRuslan Bukin /* .header = */ pt_qry_header_tsc,
13274fe6c29SRuslan Bukin /* .flags = */ pdff_timing
13374fe6c29SRuslan Bukin };
13474fe6c29SRuslan Bukin
13574fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_cbr = {
13674fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_cbr,
13774fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_cbr,
13874fe6c29SRuslan Bukin /* .header = */ pt_qry_header_cbr,
13974fe6c29SRuslan Bukin /* .flags = */ pdff_timing | pdff_event
14074fe6c29SRuslan Bukin };
14174fe6c29SRuslan Bukin
14274fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_tma = {
14374fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_tma,
14474fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_tma,
14574fe6c29SRuslan Bukin /* .header = */ pt_qry_decode_tma,
14674fe6c29SRuslan Bukin /* .flags = */ pdff_timing
14774fe6c29SRuslan Bukin };
14874fe6c29SRuslan Bukin
14974fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_mtc = {
15074fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_mtc,
15174fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_mtc,
15274fe6c29SRuslan Bukin /* .header = */ pt_qry_decode_mtc,
15374fe6c29SRuslan Bukin /* .flags = */ pdff_timing
15474fe6c29SRuslan Bukin };
15574fe6c29SRuslan Bukin
15674fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_cyc = {
15774fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_cyc,
15874fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_cyc,
15974fe6c29SRuslan Bukin /* .header = */ pt_qry_decode_cyc,
16074fe6c29SRuslan Bukin /* .flags = */ pdff_timing
16174fe6c29SRuslan Bukin };
16274fe6c29SRuslan Bukin
16374fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_stop = {
16474fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_stop,
16574fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_stop,
16674fe6c29SRuslan Bukin /* .header = */ NULL,
16774fe6c29SRuslan Bukin /* .flags = */ pdff_event
16874fe6c29SRuslan Bukin };
16974fe6c29SRuslan Bukin
17074fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_vmcs = {
17174fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_vmcs,
17274fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_vmcs,
17374fe6c29SRuslan Bukin /* .header = */ pt_qry_header_vmcs,
17474fe6c29SRuslan Bukin /* .flags = */ pdff_event
17574fe6c29SRuslan Bukin };
17674fe6c29SRuslan Bukin
17774fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_mnt = {
17874fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_mnt,
17974fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_mnt,
18074fe6c29SRuslan Bukin /* .header = */ pt_qry_header_mnt,
18174fe6c29SRuslan Bukin /* .flags = */ pdff_event
18274fe6c29SRuslan Bukin };
18374fe6c29SRuslan Bukin
18474fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_exstop = {
18574fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_exstop,
18674fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_exstop,
18774fe6c29SRuslan Bukin /* .header = */ NULL,
18874fe6c29SRuslan Bukin /* .flags = */ pdff_event
18974fe6c29SRuslan Bukin };
19074fe6c29SRuslan Bukin
19174fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_mwait = {
19274fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_mwait,
19374fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_mwait,
19474fe6c29SRuslan Bukin /* .header = */ NULL,
19574fe6c29SRuslan Bukin /* .flags = */ pdff_event
19674fe6c29SRuslan Bukin };
19774fe6c29SRuslan Bukin
19874fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_pwre = {
19974fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_pwre,
20074fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_pwre,
20174fe6c29SRuslan Bukin /* .header = */ NULL,
20274fe6c29SRuslan Bukin /* .flags = */ pdff_event
20374fe6c29SRuslan Bukin };
20474fe6c29SRuslan Bukin
20574fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_pwrx = {
20674fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_pwrx,
20774fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_pwrx,
20874fe6c29SRuslan Bukin /* .header = */ NULL,
20974fe6c29SRuslan Bukin /* .flags = */ pdff_event
21074fe6c29SRuslan Bukin };
21174fe6c29SRuslan Bukin
21274fe6c29SRuslan Bukin const struct pt_decoder_function pt_decode_ptw = {
21374fe6c29SRuslan Bukin /* .packet = */ pt_pkt_decode_ptw,
21474fe6c29SRuslan Bukin /* .decode = */ pt_qry_decode_ptw,
21574fe6c29SRuslan Bukin /* .header = */ NULL,
21674fe6c29SRuslan Bukin /* .flags = */ pdff_event
21774fe6c29SRuslan Bukin };
21874fe6c29SRuslan Bukin
21974fe6c29SRuslan Bukin
pt_df_fetch(const struct pt_decoder_function ** dfun,const uint8_t * pos,const struct pt_config * config)22074fe6c29SRuslan Bukin int pt_df_fetch(const struct pt_decoder_function **dfun, const uint8_t *pos,
22174fe6c29SRuslan Bukin const struct pt_config *config)
22274fe6c29SRuslan Bukin {
22374fe6c29SRuslan Bukin const uint8_t *begin, *end;
22474fe6c29SRuslan Bukin uint8_t opc, ext, ext2;
22574fe6c29SRuslan Bukin
22674fe6c29SRuslan Bukin if (!dfun || !config)
22774fe6c29SRuslan Bukin return -pte_internal;
22874fe6c29SRuslan Bukin
22974fe6c29SRuslan Bukin /* Clear the decode function in case of errors. */
23074fe6c29SRuslan Bukin *dfun = NULL;
23174fe6c29SRuslan Bukin
23274fe6c29SRuslan Bukin begin = config->begin;
23374fe6c29SRuslan Bukin end = config->end;
23474fe6c29SRuslan Bukin
23574fe6c29SRuslan Bukin if (!pos || (pos < begin) || (end < pos))
23674fe6c29SRuslan Bukin return -pte_nosync;
23774fe6c29SRuslan Bukin
23874fe6c29SRuslan Bukin if (pos == end)
23974fe6c29SRuslan Bukin return -pte_eos;
24074fe6c29SRuslan Bukin
24174fe6c29SRuslan Bukin opc = *pos++;
24274fe6c29SRuslan Bukin switch (opc) {
24374fe6c29SRuslan Bukin default:
24474fe6c29SRuslan Bukin /* Check opcodes that require masking. */
24574fe6c29SRuslan Bukin if ((opc & pt_opm_tnt_8) == pt_opc_tnt_8) {
24674fe6c29SRuslan Bukin *dfun = &pt_decode_tnt_8;
24774fe6c29SRuslan Bukin return 0;
24874fe6c29SRuslan Bukin }
24974fe6c29SRuslan Bukin
25074fe6c29SRuslan Bukin if ((opc & pt_opm_cyc) == pt_opc_cyc) {
25174fe6c29SRuslan Bukin *dfun = &pt_decode_cyc;
25274fe6c29SRuslan Bukin return 0;
25374fe6c29SRuslan Bukin }
25474fe6c29SRuslan Bukin
25574fe6c29SRuslan Bukin if ((opc & pt_opm_tip) == pt_opc_tip) {
25674fe6c29SRuslan Bukin *dfun = &pt_decode_tip;
25774fe6c29SRuslan Bukin return 0;
25874fe6c29SRuslan Bukin }
25974fe6c29SRuslan Bukin
26074fe6c29SRuslan Bukin if ((opc & pt_opm_fup) == pt_opc_fup) {
26174fe6c29SRuslan Bukin *dfun = &pt_decode_fup;
26274fe6c29SRuslan Bukin return 0;
26374fe6c29SRuslan Bukin }
26474fe6c29SRuslan Bukin
26574fe6c29SRuslan Bukin if ((opc & pt_opm_tip) == pt_opc_tip_pge) {
26674fe6c29SRuslan Bukin *dfun = &pt_decode_tip_pge;
26774fe6c29SRuslan Bukin return 0;
26874fe6c29SRuslan Bukin }
26974fe6c29SRuslan Bukin
27074fe6c29SRuslan Bukin if ((opc & pt_opm_tip) == pt_opc_tip_pgd) {
27174fe6c29SRuslan Bukin *dfun = &pt_decode_tip_pgd;
27274fe6c29SRuslan Bukin return 0;
27374fe6c29SRuslan Bukin }
27474fe6c29SRuslan Bukin
27574fe6c29SRuslan Bukin *dfun = &pt_decode_unknown;
27674fe6c29SRuslan Bukin return 0;
27774fe6c29SRuslan Bukin
27874fe6c29SRuslan Bukin case pt_opc_pad:
27974fe6c29SRuslan Bukin *dfun = &pt_decode_pad;
28074fe6c29SRuslan Bukin return 0;
28174fe6c29SRuslan Bukin
28274fe6c29SRuslan Bukin case pt_opc_mode:
28374fe6c29SRuslan Bukin *dfun = &pt_decode_mode;
28474fe6c29SRuslan Bukin return 0;
28574fe6c29SRuslan Bukin
28674fe6c29SRuslan Bukin case pt_opc_tsc:
28774fe6c29SRuslan Bukin *dfun = &pt_decode_tsc;
28874fe6c29SRuslan Bukin return 0;
28974fe6c29SRuslan Bukin
29074fe6c29SRuslan Bukin case pt_opc_mtc:
29174fe6c29SRuslan Bukin *dfun = &pt_decode_mtc;
29274fe6c29SRuslan Bukin return 0;
29374fe6c29SRuslan Bukin
29474fe6c29SRuslan Bukin case pt_opc_ext:
29574fe6c29SRuslan Bukin if (pos == end)
29674fe6c29SRuslan Bukin return -pte_eos;
29774fe6c29SRuslan Bukin
29874fe6c29SRuslan Bukin ext = *pos++;
29974fe6c29SRuslan Bukin switch (ext) {
30074fe6c29SRuslan Bukin default:
30174fe6c29SRuslan Bukin /* Check opcodes that require masking. */
30274fe6c29SRuslan Bukin if ((ext & pt_opm_ptw) == pt_ext_ptw) {
30374fe6c29SRuslan Bukin *dfun = &pt_decode_ptw;
30474fe6c29SRuslan Bukin return 0;
30574fe6c29SRuslan Bukin }
30674fe6c29SRuslan Bukin
30774fe6c29SRuslan Bukin *dfun = &pt_decode_unknown;
30874fe6c29SRuslan Bukin return 0;
30974fe6c29SRuslan Bukin
31074fe6c29SRuslan Bukin case pt_ext_psb:
31174fe6c29SRuslan Bukin *dfun = &pt_decode_psb;
31274fe6c29SRuslan Bukin return 0;
31374fe6c29SRuslan Bukin
31474fe6c29SRuslan Bukin case pt_ext_ovf:
31574fe6c29SRuslan Bukin *dfun = &pt_decode_ovf;
31674fe6c29SRuslan Bukin return 0;
31774fe6c29SRuslan Bukin
31874fe6c29SRuslan Bukin case pt_ext_tnt_64:
31974fe6c29SRuslan Bukin *dfun = &pt_decode_tnt_64;
32074fe6c29SRuslan Bukin return 0;
32174fe6c29SRuslan Bukin
32274fe6c29SRuslan Bukin case pt_ext_psbend:
32374fe6c29SRuslan Bukin *dfun = &pt_decode_psbend;
32474fe6c29SRuslan Bukin return 0;
32574fe6c29SRuslan Bukin
32674fe6c29SRuslan Bukin case pt_ext_cbr:
32774fe6c29SRuslan Bukin *dfun = &pt_decode_cbr;
32874fe6c29SRuslan Bukin return 0;
32974fe6c29SRuslan Bukin
33074fe6c29SRuslan Bukin case pt_ext_pip:
33174fe6c29SRuslan Bukin *dfun = &pt_decode_pip;
33274fe6c29SRuslan Bukin return 0;
33374fe6c29SRuslan Bukin
33474fe6c29SRuslan Bukin case pt_ext_tma:
33574fe6c29SRuslan Bukin *dfun = &pt_decode_tma;
33674fe6c29SRuslan Bukin return 0;
33774fe6c29SRuslan Bukin
33874fe6c29SRuslan Bukin case pt_ext_stop:
33974fe6c29SRuslan Bukin *dfun = &pt_decode_stop;
34074fe6c29SRuslan Bukin return 0;
34174fe6c29SRuslan Bukin
34274fe6c29SRuslan Bukin case pt_ext_vmcs:
34374fe6c29SRuslan Bukin *dfun = &pt_decode_vmcs;
34474fe6c29SRuslan Bukin return 0;
34574fe6c29SRuslan Bukin
34674fe6c29SRuslan Bukin case pt_ext_exstop:
34774fe6c29SRuslan Bukin case pt_ext_exstop_ip:
34874fe6c29SRuslan Bukin *dfun = &pt_decode_exstop;
34974fe6c29SRuslan Bukin return 0;
35074fe6c29SRuslan Bukin
35174fe6c29SRuslan Bukin case pt_ext_mwait:
35274fe6c29SRuslan Bukin *dfun = &pt_decode_mwait;
35374fe6c29SRuslan Bukin return 0;
35474fe6c29SRuslan Bukin
35574fe6c29SRuslan Bukin case pt_ext_pwre:
35674fe6c29SRuslan Bukin *dfun = &pt_decode_pwre;
35774fe6c29SRuslan Bukin return 0;
35874fe6c29SRuslan Bukin
35974fe6c29SRuslan Bukin case pt_ext_pwrx:
36074fe6c29SRuslan Bukin *dfun = &pt_decode_pwrx;
36174fe6c29SRuslan Bukin return 0;
36274fe6c29SRuslan Bukin
36374fe6c29SRuslan Bukin case pt_ext_ext2:
36474fe6c29SRuslan Bukin if (pos == end)
36574fe6c29SRuslan Bukin return -pte_eos;
36674fe6c29SRuslan Bukin
36774fe6c29SRuslan Bukin ext2 = *pos++;
36874fe6c29SRuslan Bukin switch (ext2) {
36974fe6c29SRuslan Bukin default:
37074fe6c29SRuslan Bukin *dfun = &pt_decode_unknown;
37174fe6c29SRuslan Bukin return 0;
37274fe6c29SRuslan Bukin
37374fe6c29SRuslan Bukin case pt_ext2_mnt:
37474fe6c29SRuslan Bukin *dfun = &pt_decode_mnt;
37574fe6c29SRuslan Bukin return 0;
37674fe6c29SRuslan Bukin }
37774fe6c29SRuslan Bukin }
37874fe6c29SRuslan Bukin }
37974fe6c29SRuslan Bukin }
380