[Libclc-dev] [PATCH 2/3] Implement degrees builtin

Aaron Watry awatry at gmail.com
Thu Feb 26 09:56:46 PST 2015


On Thu, Feb 26, 2015 at 11:07 AM, Tom Stellard <tom at stellard.net> wrote:

> On Wed, Feb 25, 2015 at 08:34:07PM -0600, Aaron Watry wrote:
> > On Wed, Feb 25, 2015 at 6:28 PM, Matt Arsenault <
> Matthew.Arsenault at amd.com>
> > wrote:
> >
> > >  On 02/25/2015 04:24 PM, Aaron Watry wrote:
> > >
> > >  Looks good to me.
> > >
> > >  Do we have a test case for this somewhere?
> > >
> > >  --Aaron
> > >
> > >  Things like this are the main thing the OpenCL conformance tests are
> > > good at
> > >
> > >
> > Yeah, that's something that I don't have access to...  I'll assume that
> > someone's been running this against the conformance tests and that the
> > tests pass.
> >
> > It just helps to note (and builds confidence in correctness) that new
> > built-in implementations have been tested against piglit, opencv, the CL
> > conformance tests, webcl conformance, etc. just to note that the
> > implementation has been tested on something other than the local dev's
> > machine.
> >
>
> I usually test against piglit, OpenCV, and a subset of the conformance
> tests before I send patches.  I can add a note in the commit message
> that these tests pass conformance.
>
> -Tom
>

I almost always check piglit for new test cases, but since OpenCV has a
tendency to lock my machine up (at least in the past), I don't often run
new patches against that.

If you've tested against opencv/conformance, there's a good chance I won't
look there and a note would be helpful :)

It's not a requirement by any means, but sometimes it'll save me time if I
know there's other existing test cases that have been run.  Mostly because
if I see new built-ins and piglit doesn't have tests for that function, my
first instinct is usually to write tests before finishing my review of the
implementation.

--Aaron


>
> > --Aaron
> >
> > >
> > >  On Tue, Feb 24, 2015 at 2:15 PM, Tom Stellard <
> thomas.stellard at amd.com>
> > > wrote:
> > >
> > >> ---
> > >>  generic/include/clc/clc.h                 |  1 +
> > >>  generic/include/clc/geometric/degrees.h   | 24 +++++++++++++++++
> > >>  generic/include/clc/geometric/degrees.inc | 23 ++++++++++++++++
> > >>  generic/lib/SOURCES                       |  1 +
> > >>  generic/lib/geometric/degrees.cl          | 45
> > >> +++++++++++++++++++++++++++++++
> > >>  5 files changed, 94 insertions(+)
> > >>  create mode 100644 generic/include/clc/geometric/degrees.h
> > >>  create mode 100644 generic/include/clc/geometric/degrees.inc
> > >>  create mode 100644 generic/lib/geometric/degrees.cl
> > >>
> > >> diff --git a/generic/include/clc/clc.h b/generic/include/clc/clc.h
> > >> index bd92fdb..02ecc1c 100644
> > >> --- a/generic/include/clc/clc.h
> > >> +++ b/generic/include/clc/clc.h
> > >> @@ -110,6 +110,7 @@
> > >>
> > >>  /* 6.11.5 Geometric Functions */
> > >>  #include <clc/geometric/cross.h>
> > >> +#include <clc/geometric/degrees.h>
> > >>  #include <clc/geometric/dot.h>
> > >>  #include <clc/geometric/length.h>
> > >>  #include <clc/geometric/normalize.h>
> > >> diff --git a/generic/include/clc/geometric/degrees.h
> > >> b/generic/include/clc/geometric/degrees.h
> > >> new file mode 100644
> > >> index 0000000..dfccdd3
> > >> --- /dev/null
> > >> +++ b/generic/include/clc/geometric/degrees.h
> > >> @@ -0,0 +1,24 @@
> > >> +/*
> > >> + * Copyright (c) 2014,2015 Advanced Micro Devices, Inc.
> > >> + *
> > >> + * Permission is hereby granted, free of charge, to any person
> obtaining
> > >> a copy
> > >> + * of this software and associated documentation files (the
> "Software"),
> > >> to deal
> > >> + * in the Software without restriction, including without limitation
> the
> > >> rights
> > >> + * to use, copy, modify, merge, publish, distribute, sublicense,
> and/or
> > >> sell
> > >> + * copies of the Software, and to permit persons to whom the
> Software is
> > >> + * furnished to do so, subject to the following conditions:
> > >> + *
> > >> + * The above copyright notice and this permission notice shall be
> > >> included in
> > >> + * all copies or substantial portions of the Software.
> > >> + *
> > >> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
> > >> EXPRESS OR
> > >> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> > >> MERCHANTABILITY,
> > >> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
> > >> SHALL THE
> > >> + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
> OTHER
> > >> + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
> > >> ARISING FROM,
> > >> + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
> > >> DEALINGS IN
> > >> + * THE SOFTWARE.
> > >> + */
> > >> +
> > >> +#define __CLC_BODY <clc/geometric/degrees.inc>
> > >> +#include <clc/geometric/floatn.inc>
> > >> diff --git a/generic/include/clc/geometric/degrees.inc
> > >> b/generic/include/clc/geometric/degrees.inc
> > >> new file mode 100644
> > >> index 0000000..c4b2247
> > >> --- /dev/null
> > >> +++ b/generic/include/clc/geometric/degrees.inc
> > >> @@ -0,0 +1,23 @@
> > >> +/*
> > >> + * Copyright (c) 2014,2015 Advanced Micro Devices, Inc.
> > >> + *
> > >> + * Permission is hereby granted, free of charge, to any person
> obtaining
> > >> a copy
> > >> + * of this software and associated documentation files (the
> "Software"),
> > >> to deal
> > >> + * in the Software without restriction, including without limitation
> the
> > >> rights
> > >> + * to use, copy, modify, merge, publish, distribute, sublicense,
> and/or
> > >> sell
> > >> + * copies of the Software, and to permit persons to whom the
> Software is
> > >> + * furnished to do so, subject to the following conditions:
> > >> + *
> > >> + * The above copyright notice and this permission notice shall be
> > >> included in
> > >> + * all copies or substantial portions of the Software.
> > >> + *
> > >> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
> > >> EXPRESS OR
> > >> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> > >> MERCHANTABILITY,
> > >> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
> > >> SHALL THE
> > >> + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
> OTHER
> > >> + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
> > >> ARISING FROM,
> > >> + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
> > >> DEALINGS IN
> > >> + * THE SOFTWARE.
> > >> + */
> > >> +
> > >> +_CLC_OVERLOAD _CLC_DECL __CLC_FLOATN degrees(__CLC_FLOATN x);
> > >> diff --git a/generic/lib/SOURCES b/generic/lib/SOURCES
> > >> index b76fec9..fd90781 100644
> > >> --- a/generic/lib/SOURCES
> > >> +++ b/generic/lib/SOURCES
> > >> @@ -29,6 +29,7 @@ cl_khr_local_int32_extended_atomics/atom_xor.cl
> > >>  convert.cl
> > >>  common/sign.cl
> > >>  geometric/cross.cl
> > >> +geometric/degrees.cl
> > >>  geometric/dot.cl
> > >>  geometric/length.cl
> > >>  geometric/normalize.cl
> > >> diff --git a/generic/lib/geometric/degrees.cl
> b/generic/lib/geometric/
> > >> degrees.cl
> > >> new file mode 100644
> > >> index 0000000..5de56f8
> > >> --- /dev/null
> > >> +++ b/generic/lib/geometric/degrees.cl
> > >> @@ -0,0 +1,45 @@
> > >> +/*
> > >> + * Copyright (c) 2014,2015 Advanced Micro Devices, Inc.
> > >> + *
> > >> + * Permission is hereby granted, free of charge, to any person
> obtaining
> > >> a copy
> > >> + * of this software and associated documentation files (the
> "Software"),
> > >> to deal
> > >> + * in the Software without restriction, including without limitation
> the
> > >> rights
> > >> + * to use, copy, modify, merge, publish, distribute, sublicense,
> and/or
> > >> sell
> > >> + * copies of the Software, and to permit persons to whom the
> Software is
> > >> + * furnished to do so, subject to the following conditions:
> > >> + *
> > >> + * The above copyright notice and this permission notice shall be
> > >> included in
> > >> + * all copies or substantial portions of the Software.
> > >> + *
> > >> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
> > >> EXPRESS OR
> > >> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> > >> MERCHANTABILITY,
> > >> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
> > >> SHALL THE
> > >> + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
> OTHER
> > >> + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
> > >> ARISING FROM,
> > >> + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
> > >> DEALINGS IN
> > >> + * THE SOFTWARE.
> > >> + */
> > >> +
> > >> +#include <clc/clc.h>
> > >> +
> > >> +#include "../clcmacro.h"
> > >> +
> > >> +_CLC_OVERLOAD _CLC_DEF float degrees(float radians) {
> > >> +  // 180/pi = ~57.29577951308232087685 or 0x1.ca5dc1a63c1f8p+5 or
> > >> 0x1.ca5dc2p+5F
> > >> +  return 0x1.ca5dc2p+5F * radians;
> > >> +}
> > >> +
> > >> +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, float, degrees, float);
> > >> +
> > >> +
> > >> +#ifdef cl_khr_fp64
> > >> +#pragma OPENCL EXTENSION cl_khr_fp64 : enable
> > >> +
> > >> +_CLC_OVERLOAD _CLC_DEF double degrees(double radians) {
> > >> +  // 180/pi = ~57.29577951308232087685 or 0x1.ca5dc1a63c1f8p+5 or
> > >> 0x1.ca5dc2p+5F
> > >> +  return 0x1.ca5dc1a63c1f8p+5 * radians;
> > >> +}
> > >> +
> > >> +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, double, degrees,
> double);
> > >> +
> > >> +#endif
> > >> --
> > >> 2.0.4
> > >>
> > >>
> > >> _______________________________________________
> > >> Libclc-dev mailing list
> > >> Libclc-dev at pcc.me.uk
> > >> http://www.pcc.me.uk/cgi-bin/mailman/listinfo/libclc-dev
> > >>
> > >
> > >
> > >
> > > _______________________________________________
> > > Libclc-dev mailing listLibclc-dev at pcc.me.ukhttp://
> www.pcc.me.uk/cgi-bin/mailman/listinfo/libclc-dev
> > >
> > >
> > >
>
> > _______________________________________________
> > Libclc-dev mailing list
> > Libclc-dev at pcc.me.uk
> > http://www.pcc.me.uk/cgi-bin/mailman/listinfo/libclc-dev
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/libclc-dev/attachments/20150226/16934fb4/attachment-0001.html>


More information about the Libclc-dev mailing list