As per the spec merely a blank isn't okay as a separator, the operand
to the relocation function ought to be parenthesized. Enforcing this
then also eliminates an inconsistency in that
	lui	t0, %hi sym
	lui	t0, %hi 0x1000
were accepted, but
	lui	t0, %hi +sym
	lui	t0, %hi -0x1000
were not.
       {
        size_t len = 1 + strlen (percent_op->str);
 
-       if (!ISSPACE ((*str)[len]) && (*str)[len] != '(')
+       while (ISSPACE ((*str)[len]))
+         ++len;
+       if ((*str)[len] != '(')
          continue;
 
        *str += len;
 
 .*: Error: illegal operands `lui x10,x11'
 .*: Error: illegal operands `auipc x12,symbol'
 .*: Error: illegal operands `lui x13,symbol'
+.*: Error: illegal operands `auipc x14,%hi symbol'
+.*: Error: illegal operands `lui x15,%hi symbol'
 
 # Don't accept a symbol without %hi() for 'u' operands.
        auipc   x12,symbol
        lui     x13,symbol
+# Don't accept reloc functions without parentheses.
+       auipc   x14,%hi symbol
+       lui     x15,%hi symbol