[Mesa-dev] [PATCH 5/7] nir/algebraic: Support specifying variable as constant or by type
Dylan Baker
baker.dylan.c at gmail.com
Thu Jan 29 17:06:19 PST 2015
On Thursday, January 29, 2015 17:00:08 Kenneth Graunke wrote:
> On Thursday, January 29, 2015 12:50:20 PM Jason Ekstrand wrote:
> > ---
> > src/glsl/nir/nir_algebraic.py | 20 +++++++++++++++++---
> > src/glsl/nir/nir_opt_algebraic.py | 12 +++++++++---
> > 2 files changed, 26 insertions(+), 6 deletions(-)
> >
> > diff --git a/src/glsl/nir/nir_algebraic.py b/src/glsl/nir/nir_algebraic.py
> > index 75436f4..6e7973d 100644
> > --- a/src/glsl/nir/nir_algebraic.py
> > +++ b/src/glsl/nir/nir_algebraic.py
> > @@ -28,6 +28,7 @@ import itertools
> > import struct
> > import sys
> > import mako.template
> > +import re
> >
> > # Represents a set of variables, each with a unique id
> > class VarSet(object):
> > @@ -65,6 +66,8 @@ static const ${val.c_type} ${val.name} = {
> > { ${hex(val)} /* ${val.value} */ },
> > % elif isinstance(val, Variable):
> > ${val.index}, /* ${val.var_name} */
> > + ${'true' if val.is_constant else 'false'},
> > + nir_type_${'void' if val.required_type is None else val.required_type},
>
> nir_type_${val.required_type or 'void'}
This is equivalent except in a few cases, namely 'void' will be picked
over any falsy value, not just None. Reasonable falsy values might be 0
or '' (empty string).
>
> > % elif isinstance(val, Expression):
> > nir_op_${val.opcode},
> > { ${', '.join(src.c_ptr for src in val.sources)} },
> > @@ -111,12 +114,23 @@ class Constant(Value):
> > else:
> > assert False
> >
> > +_var_name_re = re.compile(r"(?P<const>#)?(?P<name>\w+)(?:@(?P<type>\w+))?")
> > +
> > class Variable(Value):
> > def __init__(self, val, name, varset):
> > Value.__init__(self, name, "variable")
> > - self.var_name = val
> > - self.index = varset[val]
> > - self.name = name
> > +
> > + m = _var_name_re.match(val)
> > + assert m and m.group('name') is not None
Can m.group('name') actually be None? I don't think it can.
> > +
> > + self.var_name = m.group('name')
> > + self.is_constant = m.group('const') is not None
> > + self.required_type = m.group('type')
> > +
> > + if self.required_type is not None:
> > + assert self.required_type in ('float', 'bool', 'int', 'unsigned')
> > +
> > + self.index = varset[self.var_name]
> >
> > class Expression(Value):
> > def __init__(self, expr, name_base, varset):
> > diff --git a/src/glsl/nir/nir_opt_algebraic.py b/src/glsl/nir/nir_opt_algebraic.py
> > index 9c62b28..1dea42a 100644
> > --- a/src/glsl/nir/nir_opt_algebraic.py
> > +++ b/src/glsl/nir/nir_opt_algebraic.py
> > @@ -36,9 +36,15 @@ d = 'd'
> > # and <replace> is either an expression or a value. An expression is
> > # defined as a tuple of the form (<op>, <src0>, <src1>, <src2>, <src3>)
> > # where each source is either an expression or a value. A value can be
> > -# either a numeric constant or a string representing a variable name. For
> > -# constants, you have to be careful to make sure that it is the right type
> > -# because python is unaware of the source and destination types of the
> > +# either a numeric constant or a string representing a variable name.
> > +#
> > +# Variable names are specified as "[#]name[@type]" where "#" inicates that
> > +# the given variable will only match constants and thpe type indicates that
>
> typo ^^^^
>
> > +# the given variable will only match values from ALU instructions with the
> > +# given output type.
> > +#
> > +# For constants, you have to be careful to make sure that it is the right
> > +# type because python is unaware of the source and destination types of the
> > # opcodes.
> >
> > optimizations = [
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 473 bytes
Desc: This is a digitally signed message part.
URL: <http://lists.freedesktop.org/archives/mesa-dev/attachments/20150129/5189a624/attachment.sig>
More information about the mesa-dev
mailing list