2010-06-07 06:48:15 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_scalarmultiply_f64_ns
|
2010-10-01 08:44:37 +00:00
|
|
|
.dest 8 d1 double
|
2010-10-07 21:54:25 +00:00
|
|
|
.doubleparam 8 p1
|
2010-10-01 08:44:37 +00:00
|
|
|
|
|
|
|
muld d1, d1, p1
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_scalarmultiply_f32_ns
|
2010-08-25 16:01:57 +00:00
|
|
|
.dest 4 d1 float
|
|
|
|
.floatparam 4 p1
|
2010-06-07 06:48:15 +00:00
|
|
|
|
2010-10-01 08:42:27 +00:00
|
|
|
mulf d1, d1, p1
|
2010-06-07 06:48:15 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_int32
|
2010-10-03 09:20:37 +00:00
|
|
|
.dest 4 d1 gint32
|
|
|
|
.param 4 p1
|
|
|
|
.temp 8 t1
|
|
|
|
|
|
|
|
mulslq t1, d1, p1
|
|
|
|
shrsq t1, t1, 27
|
|
|
|
convql d1, t1
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_int32_clamp
|
2010-10-03 09:20:37 +00:00
|
|
|
.dest 4 d1 gint32
|
|
|
|
.param 4 p1
|
|
|
|
.temp 8 t1
|
|
|
|
|
|
|
|
mulslq t1, d1, p1
|
|
|
|
shrsq t1, t1, 27
|
|
|
|
convsssql d1, t1
|
2010-06-07 06:48:15 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_int16
|
2010-06-07 06:48:15 +00:00
|
|
|
.dest 2 d1 gint16
|
|
|
|
.param 2 p1
|
|
|
|
.temp 4 t1
|
|
|
|
|
|
|
|
mulswl t1, d1, p1
|
2011-05-31 09:05:03 +00:00
|
|
|
shrsl t1, t1, 11
|
2010-06-07 06:48:15 +00:00
|
|
|
convlw d1, t1
|
|
|
|
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_int16_clamp
|
2010-06-07 06:48:15 +00:00
|
|
|
.dest 2 d1 gint16
|
|
|
|
.param 2 p1
|
|
|
|
.temp 4 t1
|
|
|
|
|
|
|
|
mulswl t1, d1, p1
|
2011-05-31 09:05:03 +00:00
|
|
|
shrsl t1, t1, 11
|
2010-06-07 06:48:15 +00:00
|
|
|
convssslw d1, t1
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_int8
|
2010-06-07 06:48:15 +00:00
|
|
|
.dest 1 d1 gint8
|
|
|
|
.param 1 p1
|
|
|
|
.temp 2 t1
|
|
|
|
|
|
|
|
mulsbw t1, d1, p1
|
2011-05-31 09:05:03 +00:00
|
|
|
shrsw t1, t1, 3
|
2010-06-07 06:48:15 +00:00
|
|
|
convwb d1, t1
|
|
|
|
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_int8_clamp
|
2010-06-07 06:48:15 +00:00
|
|
|
.dest 1 d1 gint8
|
|
|
|
.param 1 p1
|
|
|
|
.temp 2 t1
|
|
|
|
|
|
|
|
mulsbw t1, d1, p1
|
2011-05-31 09:05:03 +00:00
|
|
|
shrsw t1, t1, 3
|
2010-06-07 06:48:15 +00:00
|
|
|
convssswb d1, t1
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_memset_f64
|
2010-10-01 09:00:54 +00:00
|
|
|
.dest 8 d1 gdouble
|
2010-10-07 21:54:25 +00:00
|
|
|
.doubleparam 8 p1
|
2010-10-01 09:00:54 +00:00
|
|
|
|
|
|
|
copyq d1, p1
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_prepare_volumes
|
2010-10-01 09:00:54 +00:00
|
|
|
.dest 8 d1 gdouble
|
|
|
|
.source 4 s1 gboolean
|
|
|
|
.temp 8 t1
|
|
|
|
|
|
|
|
convld t1, s1
|
|
|
|
subd t1, 0x3FF0000000000000L, t1
|
|
|
|
muld d1, d1, t1
|
2010-06-07 06:48:15 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_controlled_f64_1ch
|
2010-10-01 09:13:01 +00:00
|
|
|
.dest 8 d1 gdouble
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
|
|
|
|
muld d1, d1, s1
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_controlled_f32_1ch
|
2010-10-01 09:13:01 +00:00
|
|
|
.dest 4 d1 gfloat
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 4 t1
|
|
|
|
|
|
|
|
convdf t1, s1
|
|
|
|
mulf d1, d1, t1
|
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_controlled_f32_2ch
|
2010-10-01 09:13:01 +00:00
|
|
|
.dest 8 d1 gfloat
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 4 t1
|
|
|
|
.temp 8 t2
|
|
|
|
|
|
|
|
convdf t1, s1
|
|
|
|
mergelq t2, t1, t1
|
|
|
|
x2 mulf d1, d1, t2
|
2010-10-01 10:21:52 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_controlled_int32_1ch
|
2010-10-03 09:20:37 +00:00
|
|
|
.dest 4 d1 gint32
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 8 t1
|
|
|
|
|
2010-10-08 09:49:09 +00:00
|
|
|
convld t1, d1
|
|
|
|
muld t1, t1, s1
|
|
|
|
convdl d1, t1
|
2010-10-03 09:20:37 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_controlled_int16_1ch
|
2010-10-01 10:21:52 +00:00
|
|
|
.dest 2 d1 gint16
|
|
|
|
.source 8 s1 gdouble
|
2010-10-08 09:49:09 +00:00
|
|
|
.temp 4 t1
|
2010-10-01 10:21:52 +00:00
|
|
|
.temp 4 t2
|
|
|
|
|
2010-10-08 09:49:09 +00:00
|
|
|
convswl t1, d1
|
|
|
|
convlf t1, t1
|
|
|
|
convdf t2, s1
|
|
|
|
mulf t1, t1, t2
|
|
|
|
convfl t1, t1
|
|
|
|
convssslw d1, t1
|
2010-10-01 10:21:52 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_controlled_int16_2ch
|
2010-10-01 10:21:52 +00:00
|
|
|
.dest 4 d1 gint16
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 8 t1
|
|
|
|
.temp 4 t2
|
2010-10-08 09:49:09 +00:00
|
|
|
.temp 8 t3
|
2010-10-01 10:21:52 +00:00
|
|
|
|
2010-10-08 09:49:09 +00:00
|
|
|
x2 convswl t1, d1
|
|
|
|
x2 convlf t1, t1
|
|
|
|
convdf t2, s1
|
|
|
|
mergelq t3, t2, t2
|
|
|
|
x2 mulf t3, t3, t1
|
|
|
|
x2 convfl t3, t3
|
|
|
|
x2 convssslw d1, t3
|
2010-10-01 10:21:52 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_controlled_int8_1ch
|
2010-10-01 10:21:52 +00:00
|
|
|
.dest 1 d1 gint8
|
|
|
|
.source 8 s1 gdouble
|
2010-10-08 09:49:09 +00:00
|
|
|
.temp 2 t1
|
2010-10-01 10:21:52 +00:00
|
|
|
.temp 4 t2
|
2010-10-08 09:49:09 +00:00
|
|
|
.temp 4 t3
|
|
|
|
|
|
|
|
convsbw t1, d1
|
|
|
|
convswl t2, t1
|
|
|
|
convlf t2, t2
|
|
|
|
convdf t3, s1
|
|
|
|
mulf t2, t2, t3
|
|
|
|
convfl t2, t2
|
|
|
|
convlw t1, t2
|
|
|
|
convssswb d1, t1
|
2010-10-01 10:21:52 +00:00
|
|
|
|
2012-07-23 15:30:50 +00:00
|
|
|
.function volume_orc_process_controlled_int8_2ch
|
2010-10-01 10:21:52 +00:00
|
|
|
.dest 2 d1 gint8
|
|
|
|
.source 8 s1 gdouble
|
2010-10-08 09:49:09 +00:00
|
|
|
.temp 4 t1
|
|
|
|
.temp 8 t2
|
|
|
|
.temp 8 t3
|
|
|
|
|
|
|
|
x2 convsbw t1, d1
|
|
|
|
x2 convswl t2, t1
|
|
|
|
x2 convlf t2, t2
|
|
|
|
convdf t1, s1
|
|
|
|
mergelq t3, t1, t1
|
|
|
|
x2 mulf t2, t2, t3
|
|
|
|
x2 convfl t2, t2
|
|
|
|
x2 convlw t1, t2
|
|
|
|
x2 convssswb d1, t1
|
2010-10-01 10:21:52 +00:00
|
|
|
|