2010-06-07 06:48:15 +00:00
|
|
|
|
2010-09-09 08:57:41 +00:00
|
|
|
.init gst_volume_orc_init
|
|
|
|
|
2010-10-01 08:44:37 +00:00
|
|
|
.function orc_scalarmultiply_f64_ns
|
|
|
|
.dest 8 d1 double
|
|
|
|
.floatparam 8 p1
|
|
|
|
|
|
|
|
muld d1, d1, p1
|
|
|
|
|
2010-08-25 16:01:57 +00:00
|
|
|
.function orc_scalarmultiply_f32_ns
|
|
|
|
.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
|
|
|
|
|
|
|
|
|
|
|
.function orc_process_int16
|
|
|
|
.dest 2 d1 gint16
|
|
|
|
.param 2 p1
|
|
|
|
.temp 4 t1
|
|
|
|
|
|
|
|
mulswl t1, d1, p1
|
|
|
|
shrsl t1, t1, 13
|
|
|
|
convlw d1, t1
|
|
|
|
|
|
|
|
|
|
|
|
.function orc_process_int16_clamp
|
|
|
|
.dest 2 d1 gint16
|
|
|
|
.param 2 p1
|
|
|
|
.temp 4 t1
|
|
|
|
|
|
|
|
mulswl t1, d1, p1
|
|
|
|
shrsl t1, t1, 13
|
|
|
|
convssslw d1, t1
|
|
|
|
|
|
|
|
.function orc_process_int8
|
|
|
|
.dest 1 d1 gint8
|
|
|
|
.param 1 p1
|
|
|
|
.temp 2 t1
|
|
|
|
|
|
|
|
mulsbw t1, d1, p1
|
|
|
|
shrsw t1, t1, 5
|
|
|
|
convwb d1, t1
|
|
|
|
|
|
|
|
|
|
|
|
.function orc_process_int8_clamp
|
|
|
|
.dest 1 d1 gint8
|
|
|
|
.param 1 p1
|
|
|
|
.temp 2 t1
|
|
|
|
|
|
|
|
mulsbw t1, d1, p1
|
|
|
|
shrsw t1, t1, 5
|
|
|
|
convssswb d1, t1
|
|
|
|
|
2010-10-01 09:00:54 +00:00
|
|
|
.function orc_memset_f64
|
|
|
|
.dest 8 d1 gdouble
|
|
|
|
.floatparam 8 p1
|
|
|
|
|
|
|
|
copyq d1, p1
|
|
|
|
|
|
|
|
.function orc_prepare_volumes
|
|
|
|
.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
|
|
|
|
2010-10-01 09:13:01 +00:00
|
|
|
.function orc_process_controlled_f64_1ch
|
|
|
|
.dest 8 d1 gdouble
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
|
|
|
|
muld d1, d1, s1
|
|
|
|
|
|
|
|
.function orc_process_controlled_f32_1ch
|
|
|
|
.dest 4 d1 gfloat
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 4 t1
|
|
|
|
|
|
|
|
convdf t1, s1
|
|
|
|
mulf d1, d1, t1
|
|
|
|
|
|
|
|
.function orc_process_controlled_f32_2ch
|
|
|
|
.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
|
|
|
|
|
|
|
.function orc_process_controlled_int16_1ch
|
|
|
|
.dest 2 d1 gint16
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 8 t1
|
|
|
|
.temp 4 t2
|
|
|
|
.temp 2 t3
|
|
|
|
|
|
|
|
muld t1, s1, 0x40DFFFC000000000L
|
|
|
|
convdl t2, t1
|
|
|
|
convssslw t3, t2
|
|
|
|
mulswl t2, t3, d1
|
|
|
|
shrsl t2, t2, 16
|
|
|
|
convlw d1, t2
|
|
|
|
|
|
|
|
.function orc_process_controlled_int16_2ch
|
|
|
|
.dest 4 d1 gint16
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 8 t1
|
|
|
|
.temp 4 t2
|
|
|
|
.temp 2 t3
|
|
|
|
|
|
|
|
muld t1, s1, 0x40DFFFC000000000L
|
|
|
|
convdl t2, t1
|
|
|
|
convssslw t3, t2
|
|
|
|
mergewl t2, t3, t3
|
|
|
|
x2 mulswl t1, t2, d1
|
|
|
|
x2 shrsl t1, t1, 16
|
|
|
|
x2 convlw d1, t1
|
|
|
|
|
|
|
|
.function orc_process_controlled_int8_1ch
|
|
|
|
.dest 1 d1 gint8
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 8 t1
|
|
|
|
.temp 4 t2
|
|
|
|
.temp 2 t3
|
|
|
|
.temp 1 t4
|
|
|
|
|
|
|
|
muld t1, s1, 0x405FC00000000000L
|
|
|
|
convdl t2, t1
|
|
|
|
convlw t3, t2
|
|
|
|
convssswb t4, t3
|
|
|
|
mulsbw t3, t4, d1
|
|
|
|
shrsw t3, t3, 8
|
|
|
|
convwb d1, t3
|
|
|
|
|
|
|
|
.function orc_process_controlled_int8_2ch
|
|
|
|
.dest 2 d1 gint8
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 8 t1
|
|
|
|
.temp 4 t2
|
|
|
|
.temp 2 t3
|
|
|
|
.temp 1 t4
|
|
|
|
|
|
|
|
muld t1, s1, 0x405FC00000000000L
|
|
|
|
convdl t2, t1
|
|
|
|
convlw t3, t2
|
|
|
|
convssswb t4, t3
|
|
|
|
mergebw t3, t4, t4
|
|
|
|
x2 mulsbw t2, t3, d1
|
|
|
|
x2 shrsw t2, t2, 8
|
|
|
|
x2 convwb d1, t2
|
|
|
|
|
|
|
|
.function orc_process_controlled_int8_4ch
|
|
|
|
.dest 4 d1 gint8
|
|
|
|
.source 8 s1 gdouble
|
|
|
|
.temp 8 t1
|
|
|
|
.temp 4 t2
|
|
|
|
.temp 2 t3
|
|
|
|
.temp 1 t4
|
|
|
|
|
|
|
|
muld t1, s1, 0x405FC00000000000L
|
|
|
|
convdl t2, t1
|
|
|
|
convlw t3, t2
|
|
|
|
convssswb t4, t3
|
|
|
|
mergebw t3, t4, t4
|
|
|
|
mergewl t2, t3, t3
|
|
|
|
x4 mulsbw t1, t2, d1
|
|
|
|
x4 shrsw t1, t1, 8
|
|
|
|
x4 convwb d1, t1
|
|
|
|
|