VirtualBox

Changeset 99288 in vbox


Ignore:
Timestamp:
Apr 4, 2023 11:55:49 PM (22 months ago)
Author:
vboxsync
Message:

VMM/IEM: More work on processing MC blocks and generating threaded functions from them. bugref:10369

Location:
trunk/src/VBox/VMM/VMMAll
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/VMMAll/IEMAllInstructionsPython.py

    r99226 r99288  
    529529
    530530## \@ophints values.
     531# pylint: disable=line-too-long
    531532g_kdHints = {
    532533    'invalid':                   'DISOPTYPE_INVALID',                   ##<
     
    568569    'lock_allowed':          '',                                        ##< Lock prefix allowed.
    569570};
     571# pylint: enable=line-too-long
    570572
    571573## \@opxcpttype values (see SDMv2 2.4, 2.7).
     
    17411743
    17421744#
     1745# Decoder functions.
     1746#
     1747
     1748class DecoderFunction(object):
     1749    """
     1750    Decoder function.
     1751
     1752    This is mainly for searching for scoping searches for variables used in
     1753    microcode blocks.
     1754    """
     1755    def __init__(self, sSrcFile, iBeginLine, sName, asDefArgs):
     1756        self.sName        = sName;                  ##< The function name.
     1757        self.asDefArgs    = asDefArgs;              ##< The FNIEMOP*DEF/STUB* macro argument list, 0th element is the macro name.
     1758        self.sSrcFile     = sSrcFile;               ##< The source file the function is defined in.
     1759        self.iBeginLine   = iBeginLine;             ##< The start line.
     1760        self.iEndLine     = -1;                     ##< The line the function (probably) ends on.
     1761        self.asLines      = [] # type: list(str)    ##< The raw lines the function is made up of.
     1762
     1763    def complete(self, iEndLine, asLines):
     1764        """
     1765        Completes the function.
     1766        """
     1767        assert self.iEndLine == -1;
     1768        self.iEndLine     = iEndLine;
     1769        self.asLines      = asLines;
     1770
     1771
     1772#
    17431773# "Microcode" statements and blocks
    17441774#
     
    18871917    """
    18881918
    1889     def __init__(self, sSrcFile, iBeginLine, offBeginLine, sFunction, iInFunction, cchIndent = None):
     1919    def __init__(self, sSrcFile, iBeginLine, offBeginLine, oFunction, iInFunction, cchIndent = None):
    18901920        self.sSrcFile     = sSrcFile;                           ##< The source file containing the block.
    18911921        self.iBeginLine   = iBeginLine;                         ##< The line with the IEM_MC_BEGIN statement.
     
    18931923        self.iEndLine     = -1;                                 ##< The line with the IEM_MC_END statement.
    18941924        self.offEndLine   = 0;                                  ##< The offset of the IEM_MC_END statement within the line.
    1895         self.sFunction    = sFunction;                          ##< The function the block resides in.
     1925        self.oFunction    = oFunction;                          ##< The function the block resides in.
     1926        self.sFunction    = oFunction.sName;                    ##< The name of the function the block resides in. DEPRECATED.
    18961927        self.iInFunction  = iInFunction;                        ##< The block number wihtin the function.
    18971928        self.cchIndent    = cchIndent if cchIndent else offBeginLine;
     
    28602891        self.iCommentLine   = 0;
    28612892        self.aoCurInstrs    = []    # type: list(Instruction)
    2862         self.sCurFunction   = None  # type: str
     2893        self.oCurFunction   = None  # type: DecoderFunction
    28632894        self.iMcBlockInFunc = 0;
    28642895        self.oCurMcBlock    = None  # type: McBlock
     
    32523283        self.aoCurInstrs  = [];
    32533284        if fEndOfFunction:
    3254             #self.debug('%s: sCurFunction=None' % (self.iLine, ));
    3255             self.sCurFunction   = None;
     3285            #self.debug('%s: oCurFunction=None' % (self.iLine, ));
     3286            if self.oCurFunction:
     3287                self.oCurFunction.complete(self.iLine, self.asLines[self.oCurFunction.iBeginLine - 1 : self.iLine]);
     3288            self.oCurFunction   = None;
    32563289            self.iMcBlockInFunc = 0;
    32573290        return True;
     
    45104543
    45114544        # Check preconditions.
    4512         if not self.sCurFunction:
     4545        if not self.oCurFunction:
    45134546            self.raiseError('IEM_MC_BEGIN w/o current function (%s)' % (sCode,));
    45144547        if self.oCurMcBlock:
     
    45204553        if offPrevNewline >= 0:
    45214554            cchIndent -= offPrevNewline + 1;
    4522         #self.debug('cchIndent=%s offPrevNewline=%s sFunc=%s' % (cchIndent, offPrevNewline, self.sCurFunction));
     4555        #self.debug('cchIndent=%s offPrevNewline=%s sFunc=%s' % (cchIndent, offPrevNewline, self.oCurFunction.sName));
    45234556
    45244557        # Start a new block.
    45254558        self.oCurMcBlock = McBlock(self.sSrcFile, self.iLine, offBeginStatementInLine,
    4526                                    self.sCurFunction, self.iMcBlockInFunc, cchIndent);
     4559                                   self.oCurFunction, self.iMcBlockInFunc, cchIndent);
    45274560        g_aoMcBlocks.append(self.oCurMcBlock);
    45284561        self.cTotalMcBlocks += 1;
     
    45704603        self.oCurMcBlock.complete(self.iLine, offEndStatementInLine, asLines);
    45714604        self.oCurMcBlock = None;
     4605        return True;
     4606
     4607    def workerStartFunction(self, asArgs):
     4608        """
     4609        Deals with the start of a decoder function.
     4610
     4611        These are all defined using one of the FNIEMOP*_DEF* and FNIEMOP_*STUB*
     4612        macros, so we get a argument list for these where the 0th argument is the
     4613        macro name.
     4614        """
     4615        # Complete any existing function.
     4616        if self.oCurFunction:
     4617            self.oCurFunction.complete(self.iLine - 1, self.asLines[self.oCurFunction.iBeginLine - 1 : self.iLine - 1]);
     4618
     4619        # Create the new function.
     4620        self.oCurFunction = DecoderFunction(self.sSrcFile, self.iLine, asArgs[1], asArgs);
    45724621        return True;
    45734622
     
    45904639                                                             'FNIEMOP_UD_STUB_1' ]);
    45914640            if asArgs is not None:
    4592                 self.sCurFunction = asArgs[1];
    4593                 #self.debug('%s: sCurFunction=%s' % (self.iLine, self.sCurFunction,));
     4641                self.workerStartFunction(asArgs);
     4642                #self.debug('%s: oCurFunction=%s' % (self.iLine, self.oCurFunction.sName,));
    45944643
    45954644                if not self.aoCurInstrs:
     
    46124661                                                             'FNIEMOP_DEF_2', ]);
    46134662            if asArgs is not None:
    4614                 self.sCurFunction = asArgs[1];
    4615                 #self.debug('%s: sCurFunction=%s (%s)' % (self.iLine, self.sCurFunction, asArgs[0]));
     4663                self.workerStartFunction(asArgs);
     4664                #self.debug('%s: oCurFunction=%s (%s)' % (self.iLine, self.oCurFunction.sName, asArgs[0]));
    46164665                return True;
    46174666
  • trunk/src/VBox/VMM/VMMAll/IEMAllThreadedPython.py

    r98969 r99288  
    3838import datetime;
    3939import os;
     40import re;
    4041import sys;
    4142import argparse;
     
    222223        return None; # Shut up pylint 2.16.2.
    223224
     225    def analyzeCallToType(self, sFnRef):
     226        """
     227        Determins the type of an indirect function call.
     228        """
     229        assert sFnRef[0] == 'p';
     230
     231        #
     232        # Simple?
     233        #
     234        if sFnRef.find('-') < 0:
     235            oDecoderFunction = self.oParent.oMcBlock.oFunction;
     236
     237            # Try the argument list of the function defintion macro invocation first.
     238            iArg = 2;
     239            while iArg < len(oDecoderFunction.asDefArgs):
     240                if sFnRef == oDecoderFunction.asDefArgs[iArg]:
     241                    return oDecoderFunction.asDefArgs[iArg - 1];
     242                iArg += 1;
     243
     244            # Then check out line that includes the word and looks like a variable declaration.
     245            oRe = re.compile(' +(P[A-Z0-9_]+|const +IEMOP[A-Z0-9_]+ *[*]) +(const |) *' + sFnRef + ' *(;|=)');
     246            for sLine in oDecoderFunction.asLines:
     247                oMatch = oRe.match(sLine);
     248                if oMatch:
     249                    if not oMatch.group(1).startswith('const'):
     250                        return oMatch.group(1);
     251                    return 'PC' + oMatch.group(1)[len('const ') : -1].strip();
     252
     253        #
     254        # Deal with the pImpl->pfnXxx:
     255        #
     256        elif sFnRef.startswith('pImpl->pfn'):
     257            sMember   = sFnRef[len('pImpl->') : ];
     258            sBaseType = self.analyzeCallToType('pImpl');
     259            offBits   = sMember.rfind('U') + 1;
     260            if sBaseType == 'PCIEMOPBINSIZES':          return 'PFNIEMAIMPLBIN'         + sMember[offBits:];
     261            if sBaseType == 'PCIEMOPUNARYSIZES':        return 'PFNIEMAIMPLBIN'         + sMember[offBits:];
     262            if sBaseType == 'PCIEMOPSHIFTSIZES':        return 'PFNIEMAIMPLSHIFT'       + sMember[offBits:];
     263            if sBaseType == 'PCIEMOPSHIFTDBLSIZES':     return 'PFNIEMAIMPLSHIFTDBLU'   + sMember[offBits:];
     264            if sBaseType == 'PCIEMOPMULDIVSIZES':       return 'PFNIEMAIMPLMULDIVU'     + sMember[offBits:];
     265            if sBaseType == 'PCIEMOPMEDIAF3':           return 'PFNIEMAIMPLMEDIAF3U'    + sMember[offBits:];
     266            if sBaseType == 'PCIEMOPMEDIAOPTF3':        return 'PFNIEMAIMPLMEDIAOPTF3U' + sMember[offBits:];
     267            if sBaseType == 'PCIEMOPMEDIAOPTF2':        return 'PFNIEMAIMPLMEDIAOPTF2U' + sMember[offBits:];
     268            if sBaseType == 'PCIEMOPMEDIAOPTF3IMM8':    return 'PFNIEMAIMPLMEDIAOPTF3U' + sMember[offBits:] + 'IMM8';
     269            if sBaseType == 'PCIEMOPBLENDOP':           return 'PFNIEMAIMPLAVXBLENDU'   + sMember[offBits:];
     270
     271            self.raiseProblem('Unknown call reference: %s::%s (%s)' % (sBaseType, sMember, sFnRef,));
     272
     273        self.raiseProblem('Unknown call reference: %s' % (sFnRef,));
     274        return None; # Shut up pylint 2.16.2.
     275
    224276    def analyzeMorphStmtForThreaded(self, aoStmts, iParamRef = 0):
    225277        """
     
    430482            if isinstance(oStmt, iai.McStmtCall):
    431483                if oStmt.sFn[0] == 'p':
    432                     self.aoParamRefs.append(ThreadedParamRef(oStmt.sFn, 'uintptr_t', oStmt, oStmt.idxFn));
     484                    self.aoParamRefs.append(ThreadedParamRef(oStmt.sFn, self.analyzeCallToType(oStmt.sFn), oStmt, oStmt.idxFn));
    433485                elif (    oStmt.sFn[0] != 'i'
    434486                      and not oStmt.sFn.startswith('IEMTARGETCPU_EFL_BEHAVIOR_SELECT')
     
    588640    def dummyInstance():
    589641        """ Gets a dummy instance. """
    590         return ThreadedFunction(iai.McBlock('null', 999999999, 999999999, 'nil', 999999999));
     642        return ThreadedFunction(iai.McBlock('null', 999999999, 999999999,
     643                                            iai.DecoderFunction('null', 999999999, 'nil', ('','')), 999999999));
    591644
    592645    def raiseProblem(self, sMessage):
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette