forked from mer-hybris/pulseaudio-modules-droid
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmeson.build
172 lines (144 loc) · 5.02 KB
/
meson.build
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
project('pulseaudio-modules-droid', 'c',
version : run_command(find_program('git-version-gen'), join_paths(meson.current_source_dir(), '.tarball-version'), check: true).stdout().strip(),
meson_version : '>= 0.50.0',
default_options : [ 'c_std=gnu11' ]
)
cc = meson.get_compiler('c')
configinc = include_directories('.')
libdir = join_paths(get_option('prefix'), get_option('libdir'))
pa_c_args = ['-DHAVE_CONFIG_H']
droiddevice = get_option('droid-device')
pa_c_args += ['-DDROID_DEVICE_@0@=1'.format(droiddevice.underscorify().to_upper())]
pa_c_args += ['-DDROID_DEVICE_STRING="@0@"'.format(droiddevice)]
# dependencies
droid_headers_dep = dependency('android-headers', required : true)
expat_dep = dependency('expat', version : '>= 2.1', required : true)
hybris_dep = dependency('libhardware', version : '>= 0.1.0', required : true)
hybris_common_dep = cc.find_library('hybris-common', required : true)
ltdl_dep = cc.find_library('ltdl', required : true)
pulsecore_dep = dependency('pulsecore', version : '>= 14.2', required : true)
pa_version_str = meson.project_version()
# For tarballs, the first split will do nothing, but for builds in git, we
# split out suffixes when there are commits since the last tag
# (e.g.: v11.99.1-3-gad14bdb24 -> v11.99.1)
version_split = pa_version_str.split('-')[0].split('.')
pa_version_major = version_split[0].split('v')[0]
pa_version_minor = version_split[1]
pa_version_module = version_split[2].split('+')[0]
pa_version_major_minor = pa_version_major + '.' + pa_version_minor
modlibexecdir = get_option('modlibexecdir')
if modlibexecdir == ''
modlibexecdir = join_paths(libdir, 'pulse-' + pa_version_major_minor, 'modules')
endif
privlibdir = join_paths(libdir, 'pulseaudio')
rpath_dirs = join_paths(privlibdir) + ':' + join_paths(modlibexecdir)
cdata = configuration_data()
cdata.set_quoted('PACKAGE', meson.project_name())
cdata.set_quoted('PACKAGE_NAME', meson.project_name())
cdata.set_quoted('PACKAGE_VERSION', pa_version_str)
cdata.set_quoted('VERSION', pa_version_str)
# Atomic operations
if get_option('atomic-arm-memory-barrier')
cdata.set('ATOMIC_ARM_MEMORY_BARRIER_ENABLED', 1)
endif
need_libatomic_ops = false
atomictest = '''void func() {
volatile int atomic = 2;
__sync_bool_compare_and_swap (&atomic, 2, 3);
}
'''
if cc.compiles(atomictest)
cdata.set('HAVE_ATOMIC_BUILTINS', 1)
newatomictest = '''void func() {
int c = 0;
__atomic_store_n(&c, 4, __ATOMIC_SEQ_CST);
}
'''
if(cc.compiles(newatomictest))
cdata.set('HAVE_ATOMIC_BUILTINS_MEMORY_MODEL', 1)
endif
elif host_machine.cpu_family() == 'arm'
if host_machine.system() == 'linux' and get_option('atomic-arm-linux-helpers')
cdata.set('ATOMIC_ARM_LINUX_HELPERS', 1)
else
armatomictest = '''int func() {
volatile int a=0;
int o=0, n=1, r;
asm volatile (
"ldrex %0, [%1]\n"
"subs %0, %0, %2\n"
"strexeq %0, %3, [%1]\n"
: "=&r" (r)
: "r" (&a), "Ir" (o), "r" (n)
: "cc");
return (a==1 ? 0 : -1);
}
'''
if cc.compiles(armatomictest)
cdata.set('ATOMIC_ARM_INLINE_ASM', 1)
else
need_libatomic_ops = true
endif
endif # arm && !linux
elif not ['freebsd', 'netbsd'].contains(host_machine.system())
need_libatomic_ops = true
endif # !atomic helpers && !arm
if need_libatomic_ops
assert(cc.has_header('atomic_ops.h'), 'Need libatomic_ops')
cdata.set('AO_REQUIRE_CAS', 1)
if host_machine.system() != 'windows'
libatomic_ops_dep = cc.find_library('atomic_ops', required : true)
else
libatomic_ops_dep = dependency('', required: false)
endif
else
libatomic_ops_dep = dependency('', required: false)
endif
check_enums = [
# Input devices
'AUDIO_DEVICE_IN_FM_RX',
'AUDIO_DEVICE_IN_FM_RX_A2DP',
# Audio sources
'AUDIO_SOURCE_ECHO_REFERENCE',
'AUDIO_SOURCE_FM_TUNER',
'AUDIO_SOURCE_FM_RX',
'AUDIO_SOURCE_FM_RX_A2DP',
# Output flags
'AUDIO_OUTPUT_FLAG_COMPRESS_PASSTHROUGH',
# Channels
'AUDIO_CHANNEL_IN_VOICE_CALL_MONO',
'AUDIO_CHANNEL_IN_VOICE_UPLINK_MONO',
'AUDIO_CHANNEL_IN_VOICE_DNLINK_MONO',
# Formats
'AUDIO_FORMAT_PCM_OFFLOAD',
'AUDIO_FORMAT_FLAC',
'AUDIO_FORMAT_OPUS',
]
foreach e : check_enums
if cc.has_header_symbol('system/audio.h', e, dependencies : droid_headers_dep, prefix : '#include <android-config.h>\n#ifdef QCOM_BSP\n#define QCOM_HARDWARE\n#endif')
define = 'HAVE_ENUM_' + e
cdata.set(define, 1)
define = 'STRING_ENTRY_IF_' + e
cdata.set(define, 'STRING_ENTRY(' + e + '),')
define = 'FANCY_ENTRY_IF_' + e + '(n)'
cdata.set(define, '{' + e + ', n},')
else
define = 'STRING_ENTRY_IF_' + e
cdata.set(define, '')
define = 'FANCY_ENTRY_IF_' + e + '(n)'
cdata.set(define, '')
endif
endforeach
# Headers
check_headers = [
'valgrind/memcheck.h',
]
foreach h : check_headers
if cc.has_header(h)
define = 'HAVE_' + h.underscorify().to_upper()
cdata.set(define, 1)
endif
endforeach
# Now generate config.h from everything above
configure_file(output : 'config.h', configuration : cdata)
subdir('src')