111
|
1 /* queue.c -- Builtins for HSAIL queue related instructions.
|
|
2
|
131
|
3 Copyright (C) 2015-2018 Free Software Foundation, Inc.
|
111
|
4 Contributed by Pekka Jaaskelainen <pekka.jaaskelainen@parmance.com>
|
|
5 for General Processor Tech.
|
|
6
|
|
7 Permission is hereby granted, free of charge, to any person obtaining a
|
|
8 copy of this software and associated documentation files
|
|
9 (the "Software"), to deal in the Software without restriction, including
|
|
10 without limitation the rights to use, copy, modify, merge, publish,
|
|
11 distribute, sublicense, and/or sell copies of the Software, and to
|
|
12 permit persons to whom the Software is furnished to do so, subject to
|
|
13 the following conditions:
|
|
14
|
|
15 The above copyright notice and this permission notice shall be included
|
|
16 in all copies or substantial portions of the Software.
|
|
17
|
|
18 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
19 OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
20 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
21 IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
|
22 DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
|
23 OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
|
24 USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
25 */
|
|
26
|
|
27 #include "phsa-queue-interface.h"
|
|
28
|
|
29 uint64_t
|
|
30 __hsail_ldqueuereadindex (uint64_t queue_addr)
|
|
31 {
|
|
32 phsa_queue_t *queue = (phsa_queue_t *) (uintptr_t) queue_addr;
|
|
33 return queue->read_index;
|
|
34 }
|
|
35
|
|
36 uint64_t
|
|
37 __hsail_ldqueuewriteindex (uint64_t queue_addr)
|
|
38 {
|
|
39 phsa_queue_t *queue = (phsa_queue_t *) (uintptr_t) queue_addr;
|
|
40 return queue->write_index;
|
|
41 }
|
|
42
|
|
43 uint64_t
|
|
44 __hsail_addqueuewriteindex (uint64_t queue_addr, uint64_t value)
|
|
45 {
|
|
46 phsa_queue_t *queue = (phsa_queue_t *) (uintptr_t) queue_addr;
|
|
47 return __sync_fetch_and_add (&queue->write_index, value);
|
|
48 }
|
|
49
|
|
50 uint64_t
|
|
51 __hsail_casqueuewriteindex (uint64_t queue_addr, uint64_t cmp_value,
|
|
52 uint64_t new_value)
|
|
53 {
|
|
54 phsa_queue_t *queue = (phsa_queue_t *) (uintptr_t) queue_addr;
|
|
55 return __sync_val_compare_and_swap (&queue->write_index, cmp_value,
|
|
56 new_value);
|
|
57 }
|
|
58
|
|
59 void
|
|
60 __hsail_stqueuereadindex (uint64_t queue_addr, uint64_t value)
|
|
61 {
|
|
62 phsa_queue_t *queue = (phsa_queue_t *) (uintptr_t) queue_addr;
|
|
63 queue->read_index = value;
|
|
64 }
|
|
65
|
|
66 void
|
|
67 __hsail_stqueuewriteindex (uint64_t queue_addr, uint64_t value)
|
|
68 {
|
|
69 phsa_queue_t *queue = (phsa_queue_t *) (uintptr_t) queue_addr;
|
|
70 queue->write_index = value;
|
|
71 }
|