aboutsummaryrefslogtreecommitdiffstats
path: root/mibs/Intel-Rdt.txt
blob: 8eb93d0a97a533d83b6d78085377942df0357096 (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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
INTEL-RDT-MIB DEFINITIONS ::= BEGIN

IMPORTS
    MODULE-IDENTITY, OBJECT-TYPE, Integer32, Counter64
        FROM SNMPv2-SMI

    hostAssist
        FROM Intel-SA-MIB

    DisplayString
        FROM SNMPv2-TC;

--*****************************************************************************
--
-- MODULE IDENTITY AND REVISION GROUP
--
--*****************************************************************************

intelRdt            MODULE-IDENTITY
    LAST-UPDATED    "201610241700Z" -- coordinated universal time UTC format is YYMMDDHHmmZ
    ORGANIZATION    "Intel, Server Management Software"
    CONTACT-INFO    " "
    DESCRIPTION     "This SNMP MIB module supports the Intel RDT SNMP subagent for monitoring
                    information provided by monitoring features of Intel Resource Director
                    Technology (Intel(R) RDT) like Cache Monitoring Technology (CMT),
                    Memory Bandwidth Monitoring (MBM). These features provide information about
                    utilization of shared resources like last level cache occupancy, local
                    memory bandwidth usage, remote memory bandwidth usage, instructions per clock.

                    Version:  1.0   10/24/2016

                    Intel copyright information 2016"
                    ::= { hostAssist 1 }

OneBasedIndex       ::= Integer32(1..2147483647)

-------------------------------------------------------------------------------
-- Intel RDT Table
-------------------------------------------------------------------------------

rdtGroupNumber  OBJECT-TYPE
    SYNTAX      Integer32
    MAX-ACCESS  read-only
    STATUS      current
    DESCRIPTION
            "The number of network interfaces (regardless of their
            current state) present on this system."
    ::= { intelRdt 1 }

rdtTable                                    OBJECT-TYPE
    SYNTAX      SEQUENCE OF RdtTableEntry
    MAX-ACCESS  not-accessible
    STATUS      current
    DESCRIPTION
            "This Group defines the Intel RDT Groups Table."
    ::= { intelRdt 2 }

rdtTableEntry                               OBJECT-TYPE
    SYNTAX      RdtTableEntry
    MAX-ACCESS  not-accessible
    STATUS      current
    DESCRIPTION "This Group defines the Intel RDT Groups Table Entry."
    INDEX       { rdtGroupIndex }
    ::= { rdtTable 1 }

RdtTableEntry                                      ::= SEQUENCE {
    rdtGroupIndex                                  OneBasedIndex,
    rdtGroupDescr                                  DisplayString,
    rdtLlc                                         Counter64,
    rdtIpc                                         Counter64,
    rdtMbmRemote                                   Counter64,
    rdtMbmLocal                                    Counter64
}

rdtGroupIndex OBJECT-TYPE
    SYNTAX      OneBasedIndex
    MAX-ACCESS  read-only
    STATUS      current
    DESCRIPTION
            "This attribute defines the index of the Intel RDT group."
    ::= { rdtTableEntry 1 }

rdtGroupDescr OBJECT-TYPE
    SYNTAX      DisplayString (SIZE (0..255))
    MAX-ACCESS  read-only
    STATUS      current
    DESCRIPTION
            "A textual string containing information about the groups of cores
             on which to monitor supported events."
    ::= { rdtTableEntry 2 }

rdtLlc OBJECT-TYPE
    SYNTAX      Counter64
    UNITS       "bytes"
    MAX-ACCESS  read-only
    STATUS      current
    DESCRIPTION
            "This counter defines the last level cache occupancy."
    ::= { rdtTableEntry 3 }

rdtIpc OBJECT-TYPE
    SYNTAX      DisplayString
    UNITS       "ipc"
    MAX-ACCESS  read-only
    STATUS      current
    DESCRIPTION
            "This counter defines the instructions per clock."
    ::= { rdtTableEntry 4 }

rdtMbmRemote OBJECT-TYPE
    SYNTAX      Counter64
    UNITS       "bytes/sec"
    MAX-ACCESS  read-only
    STATUS      current
    DESCRIPTION
            "This counter defines the Remote (Socket) memory bandwidth usage."
    ::= { rdtTableEntry 5 }

rdtMbmLocal OBJECT-TYPE
    SYNTAX      Counter64
    UNITS       "bytes/sec"
    MAX-ACCESS  read-only
    STATUS      current
    DESCRIPTION
            "This counter defines the Local (Socket) memory bandwidth usage."
    ::= { rdtTableEntry 6 }

END
lass="p">; then # no bc, so do integer comparison only int_rating=`echo $1 | sed -e 's/\..*$//'` int_rating_min=`echo $PYLINT_RATING_MIN | sed -e 's/\..*$//'` [ $int_rating -lt $int_rating_min ] && PYLINT_RATING_MIN=$int_rating if [ $int_rating -lt $PYLINT_RATING_GATE ] ; then return 1 else return 0 fi else if (( $(echo "$1<$PYLINT_RATING_MIN" | bc -l) )) ; then PYLINT_RATING_MIN=$1 fi if (( $(echo "$1<$PYLINT_RATING_GATE" | bc -l) )) ; then return 1 else return 0 fi fi } ##### MAIN ##### # check if help is requested if [ "x$1" == "x-h" -o "x$1" == "x--help" ] ; then usage exit 0 fi # set colours if [ "x$1" == "x-b" -o "x$1" == "x--black" ] ; then shift RED="" GREEN="" BLACK="" else RED="\e[31m" GREEN="\e[32m" BLACK="\e[0m" fi # check if pylint is available if ! which $PYLINT &>/dev/null ; then echo "$PYLINT is not available, thus check can't be executed" exit 1 fi # check if we were run within vsperf directory if [ ! -x ./vsperf 2> /dev/null ] ; then echo "`basename $0` must be run from vsperf root directory" exit 2 fi # get list of excluded modules EXCLUDED_MODULES=`grep "^ *EXCLUDE_MODULES" conf/00_common.conf | tr '"' "'"` # get list of files to be checked rm $FILE_LIST &> /dev/null if [ "x$1" == "x-m" -o "x$1" == "x--modified" ] ; then # check of modified files requested git status --porcelain | cut -b4- | egrep -i "${FILE_REGEX}" | sort > $FILE_LIST elif [ "x$*" == "x" ] ; then # list is empty, check all python files git ls-tree --name-only -r HEAD | egrep -i "${FILE_REGEX}" | sort > $FILE_LIST else for item in $* ; do if [ -d $item ] ; then git ls-tree --name-only -r HEAD $item | egrep -i "${FILE_REGEX}" | sort >> $FILE_LIST elif [ -f $item ] ; then echo $item >> $FILE_LIST else echo "$item doesn't exist, thus check was aborted" exit 3 fi done fi # check if there is anything to check echo "Execution of pylint checks:" if [ -s $FILE_LIST ] ; then for pyfile in `cat $FILE_LIST | sort` ; do # get base name pyfile_basename="'"`basename $pyfile .py`"'" # and check if it should be excluded or not if ( echo $EXCLUDED_MODULES | grep -w $pyfile_basename > /dev/null ) ; then printf " %-70s %-6s\n" $pyfile "EXCLUDED" continue fi # run pylint and extract final rating output=`$PYLINT --rcfile $PYLINT_RC $pyfile 2>/dev/null` rating=`echo -e $output | tail -n3 | grep rated | sed -e 's/^.*rated at \([0-9.]*\).*$/\1/'` # evaluate and display aquired rating if [ "x$rating" == "x" ] ; then # rating is not available for files without python statements printf " %-70s %-6s\n" $pyfile "NA" elif rating_is_ok $rating ; then printf " %-70s ${GREEN}%-6s${BLACK}\n" $pyfile "OK" else echo -e "$output" | awk '/^*+ Module|^[A-Z]\:/' printf " %-70s ${RED}%-6s${BLACK}\n" $pyfile $rating fi done else echo "Nothing to check." exit 4 fi # clean up rm $FILE_LIST &> /dev/null if [ "$PYLINT_RATING_MIN" != "$PYLINT_RATING_GATE" ] ; then echo -e "Pylint check has failed. All files must have score ${PYLINT_RATING_GATE}.\n" exit 1 else exit 0 fi ##### MAIN end #####