From: Richard Sandiford <richard.sandiford@arm.com>
To: "Andre Vieira \(lists\)" <andre.simoesdiasvieira@arm.com>
Cc: "Andre Vieira \(lists\) via Gcc-patches"
<gcc-patches@gcc.gnu.org>, Richard Biener <rguenther@suse.de>
Subject: Re: [AArch64] Enable generation of FRINTNZ instructions
Date: Wed, 29 Dec 2021 16:54:09 +0000 [thread overview]
Message-ID: <mptzgoj2vym.fsf@arm.com> (raw)
In-Reply-To: <9d3755df-6c41-20e4-31fb-811e5cd9182a@arm.com> (Andre Vieira's message of "Wed, 29 Dec 2021 15:55:41 +0000")
"Andre Vieira (lists)" <andre.simoesdiasvieira@arm.com> writes:
> On 17/12/2021 12:44, Richard Sandiford wrote:
>>
>>> @@ -3252,16 +3257,31 @@ vectorizable_call (vec_info *vinfo,
>>> rhs_type = unsigned_type_node;
>>> }
>>>
>>> - int mask_opno = -1;
>>> + /* The argument that is not of the same type as the others. */
>>> + int diff_opno = -1;
>>> + bool masked = false;
>>> if (internal_fn_p (cfn))
>>> - mask_opno = internal_fn_mask_index (as_internal_fn (cfn));
>>> + {
>>> + if (cfn == CFN_FTRUNC_INT)
>>> + /* For FTRUNC this represents the argument that carries the type of the
>>> + intermediate signed integer. */
>>> + diff_opno = 1;
>>> + else
>>> + {
>>> + /* For masked operations this represents the argument that carries the
>>> + mask. */
>>> + diff_opno = internal_fn_mask_index (as_internal_fn (cfn));
>>> + masked = diff_opno >= 0;
>>> + }
>>> + }
>> I think it would be cleaner not to process argument 1 at all for
>> CFN_FTRUNC_INT. There's no particular need to vectorise it.
>
> I agree with this, will change the loop to continue for argument 1 when
> dealing with non-masked CFN's.
>
>>> }
>>> […]
>>> diff --git a/gcc/tree.c b/gcc/tree.c
>>> index 845228a055b2cfac0c9ca8c0cda1b9df4b0095c6..f1e9a1eb48769cb11aa69730e2480ed5522f78c1 100644
>>> --- a/gcc/tree.c
>>> +++ b/gcc/tree.c
>>> @@ -6645,11 +6645,11 @@ valid_constant_size_p (const_tree size, cst_size_error *perr /* = NULL */)
>>> return true;
>>> }
>>>
>>> -/* Return the precision of the type, or for a complex or vector type the
>>> - precision of the type of its elements. */
>>> +/* Return the type, or for a complex or vector type the type of its
>>> + elements. */
>>>
>>> -unsigned int
>>> -element_precision (const_tree type)
>>> +tree
>>> +element_type (const_tree type)
>>> {
>>> if (!TYPE_P (type))
>>> type = TREE_TYPE (type);
>>> @@ -6657,7 +6657,16 @@ element_precision (const_tree type)
>>> if (code == COMPLEX_TYPE || code == VECTOR_TYPE)
>>> type = TREE_TYPE (type);
>>>
>>> - return TYPE_PRECISION (type);
>>> + return (tree) type;
>> I think we should stick a const_cast in element_precision and make
>> element_type take a plain “type”. As it stands element_type is an
>> implicit const_cast for many cases.
>>
>> Thanks,
> Was just curious about something here, I thought the purpose of having
> element_precision (before) and element_type (now) take a const_tree as
> an argument was to make it clear we aren't changing the input type. I
> understand that as it stands element_type could be an implicit
> const_cast (which I should be using rather than the '(tree)' cast), but
> that's only if 'type' is a type that isn't complex/vector, either way,
> we are conforming to the promise that we aren't changing the incoming
> type, what the caller then does with the result is up to them no?
>
> I don't mind making the changes, just trying to understand the reasoning
> behind it.
The problem with the above is that functions like the following become
well-typed:
void
foo (const_tree t)
{
TYPE_MODE (element_type (t)) = VOIDmode;
}
even though element_type (t) could well be t.
One of the points of const_tree (and const pointer targets in general)
is to use the type system to enforce the promise that the value isn't
changed.
I guess the above is similar to the traditional problem with functions
like index and strstr, which take a const char * but return a char *.
So for example:
void
foo (const char *x)
{
index (x, '.') = 0;
}
is well-typed. But the equivalent C++ code (using iterators) would be
rejected. If C allowed overloading them the correct prototypes would be:
const char *index (const char *, int);
char *index (char *, int);
And I think the same applies here. Either we should provide two functions:
const_tree element_type (const_tree);
tree element_type (tree);
or just the latter.
Thanks,
Richard
next prev parent reply other threads:[~2021-12-29 16:54 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-11-11 17:51 Andre Vieira (lists)
2021-11-12 10:56 ` Richard Biener
2021-11-12 11:48 ` Andre Simoes Dias Vieira
2021-11-16 12:10 ` Richard Biener
2021-11-17 13:30 ` Andre Vieira (lists)
2021-11-17 15:38 ` Richard Sandiford
2021-11-18 11:05 ` Richard Biener
2021-11-22 11:38 ` Andre Vieira (lists)
2021-11-22 11:41 ` Richard Biener
2021-11-25 13:53 ` Andre Vieira (lists)
2021-12-07 11:29 ` Andre Vieira (lists)
2021-12-17 12:44 ` Richard Sandiford
2021-12-29 15:55 ` Andre Vieira (lists)
2021-12-29 16:54 ` Richard Sandiford [this message]
2022-01-03 12:18 ` Richard Biener
2022-01-10 14:09 ` Andre Vieira (lists)
2022-01-10 14:45 ` Richard Biener
2022-01-14 10:37 ` Richard Sandiford
2022-11-04 17:40 ` Andre Vieira (lists)
2022-11-07 11:05 ` Richard Biener
2022-11-07 14:19 ` Andre Vieira (lists)
2022-11-07 14:56 ` Richard Biener
2022-11-09 11:33 ` Andre Vieira (lists)
2022-11-15 18:24 ` Richard Sandiford
2022-11-16 12:25 ` Richard Biener
2021-11-29 11:17 ` Andre Vieira (lists)
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=mptzgoj2vym.fsf@arm.com \
--to=richard.sandiford@arm.com \
--cc=andre.simoesdiasvieira@arm.com \
--cc=gcc-patches@gcc.gnu.org \
--cc=rguenther@suse.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).