Print this page
5362 invalid conversion when using asm/thread.h in c++ code
Split |
Close |
Expand all |
Collapse all |
--- old/usr/src/uts/intel/asm/thread.h
+++ new/usr/src/uts/intel/asm/thread.h
1 1 /*
2 2 * CDDL HEADER START
3 3 *
4 4 * The contents of this file are subject to the terms of the
5 5 * Common Development and Distribution License, Version 1.0 only
6 6 * (the "License"). You may not use this file except in compliance
7 7 * with the License.
8 8 *
9 9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 10 * or http://www.opensolaris.org/os/licensing.
11 11 * See the License for the specific language governing permissions
12 12 * and limitations under the License.
13 13 *
14 14 * When distributing Covered Code, include this CDDL HEADER in each
↓ open down ↓ |
14 lines elided |
↑ open up ↑ |
15 15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 16 * If applicable, add the following below this CDDL HEADER, with the
17 17 * fields enclosed by brackets "[]" replaced with your own identifying
18 18 * information: Portions Copyright [yyyy] [name of copyright owner]
19 19 *
20 20 * CDDL HEADER END
21 21 */
22 22 /*
23 23 * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
24 24 * Use is subject to license terms.
25 + * Copyright 2014 Nexenta Systems, Inc. All rights reserved.
25 26 */
26 27
27 28 #ifndef _ASM_THREAD_H
28 29 #define _ASM_THREAD_H
29 30
30 31 #include <sys/ccompile.h>
31 32 #include <sys/types.h>
32 33
33 34 #ifdef __cplusplus
34 35 extern "C" {
35 36 #endif
36 37
37 38 #if !defined(__lint) && defined(__GNUC__)
38 39
39 40 struct _kthread;
40 41
↓ open down ↓ |
6 lines elided |
↑ open up ↑ |
41 42 /*
42 43 * 0x10 is offsetof(struct cpu, cpu_thread)
43 44 * 0x18 is the same thing for the _LP64 version.
44 45 * (It's also the value of CPU_THREAD in assym.h)
45 46 * Yuck.
46 47 */
47 48
48 49 extern __GNU_INLINE struct _kthread
49 50 *threadp(void)
50 51 {
51 - void *__value;
52 + struct _kthread *__value;
52 53
53 54 #if defined(__amd64)
54 55 __asm__ __volatile__(
55 56 "movq %%gs:0x18,%0" /* CPU_THREAD */
56 57 : "=r" (__value));
57 58 #elif defined(__i386)
58 59 __asm__ __volatile__(
59 60 "movl %%gs:0x10,%0" /* CPU_THREAD */
60 61 : "=r" (__value));
61 62 #else
62 63 #error "port me"
63 64 #endif
64 65 return (__value);
65 66 }
66 67
67 68 #endif /* !__lint && __GNUC__ */
68 69
69 70 #ifdef __cplusplus
70 71 }
71 72 #endif
72 73
73 74 #endif /* _ASM_THREAD_H */
↓ open down ↓ |
12 lines elided |
↑ open up ↑ |
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX