A std_logic_vector is just an array of bits.
If I happen to know that the value is signed, the
msb is usually the sign bit, but I certainly can't
determine the type by the value of the msb.
-- Mike Treseler
Dan,
What Mike is trying to say, is that your original question states you
want to determine whether a value is signed or unsigned. Those are
representations (types), not values. If you meant "negative or
positive", and you know the representation is signed (obviously,
otherwise there would be no negative values to consider), then, yes
the MSB will tell you that. Otherwise, the MSB value tells you nothing
about representation.
This is the reasoning behind the numeric_std package and its
definitions of types signed and unsigned: because it is impossible for
VHDL to know the numeric representation of an SLV. Defining the data
as signed or unsigned (by putting it in the appropriate type of signal
or variable) allows VHDL to automatically select the appropriate
operator version to ensure that the results are arithmetically
correct.
Andy