1135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent/*
2135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * Copyright (C) 2010 The Android Open Source Project
3135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent *
4135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * Licensed under the Apache License, Version 2.0 (the "License");
5135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * you may not use this file except in compliance with the License.
6135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * You may obtain a copy of the License at
7135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent *
8135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent *      http://www.apache.org/licenses/LICENSE-2.0
9135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent *
10135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * Unless required by applicable law or agreed to in writing, software
11135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * distributed under the License is distributed on an "AS IS" BASIS,
12135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * See the License for the specific language governing permissions and
14135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent * limitations under the License.
15135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent */
16135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
17135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent#ifndef ANDROID_EFFECTSFACTORY_H_
18135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent#define ANDROID_EFFECTSFACTORY_H_
19135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
20135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent#include <dirent.h>
2160d02077d86d2d1092443519290101f503aa6f7aMark Salyzyn#include <pthread.h>
2260d02077d86d2d1092443519290101f503aa6f7aMark Salyzyn
2360d02077d86d2d1092443519290101f503aa6f7aMark Salyzyn#include <android/log.h>
24f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana#include <hardware/audio_effect.h>
25135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
26135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent#if __cplusplus
27135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurentextern "C" {
28135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent#endif
29135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
3020569262fce8b047bfc253d91ccb0f455863fde1Jean-Michel Trivi#define PROPERTY_IGNORE_EFFECTS "ro.audio.ignore_effects"
31e1315cf0b63b4c14a77046519e6b01f6f60d74b0Eric Laurent
32135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurenttypedef struct list_elem_s {
33135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent    void *object;
34135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent    struct list_elem_s *next;
35135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent} list_elem_t;
36135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
372eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana// Structure used for storing effects with their sub effects.
382eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana// Used in creating gSubEffectList. Here,
392eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana// object holds the effect desc and the list sub_elem holds the sub effects
402eab94f7dfd41a65e13aca379a1aed97447f8884jpadmanatypedef struct list_sub_elem_s {
412eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana    void *object;
422eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana    list_elem_t *sub_elem;
432eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana    struct list_sub_elem_s *next;
442eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana} list_sub_elem_t;
452eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana
46135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurenttypedef struct lib_entry_s {
47e1315cf0b63b4c14a77046519e6b01f6f60d74b0Eric Laurent    audio_effect_library_t *desc;
48e1315cf0b63b4c14a77046519e6b01f6f60d74b0Eric Laurent    char *name;
49e1315cf0b63b4c14a77046519e6b01f6f60d74b0Eric Laurent    char *path;
50135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent    void *handle;
51135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent    list_elem_t *effects; //list of effect_descriptor_t
52135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent    pthread_mutex_t lock;
53135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent} lib_entry_t;
54135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
55135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurenttypedef struct effect_entry_s {
56135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent    struct effect_interface_s *itfe;
57e1315cf0b63b4c14a77046519e6b01f6f60d74b0Eric Laurent    effect_handle_t subItfe;
58135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent    lib_entry_t *lib;
59135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent} effect_entry_t;
60135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
61090eb09be1600b101b6d6e4e092f30763776bc80ragotypedef struct lib_failed_entry_s {
62090eb09be1600b101b6d6e4e092f30763776bc80rago    char *name;
63090eb09be1600b101b6d6e4e092f30763776bc80rago    char *path;
64090eb09be1600b101b6d6e4e092f30763776bc80rago} lib_failed_entry_t;
65090eb09be1600b101b6d6e4e092f30763776bc80rago
662eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana// Structure used to store the lib entry
672eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana// and the descriptor of the sub effects.
682eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana// The library entry is to be stored in case of
692eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana// sub effects as the sub effects are not linked
702eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana// to the library list - gLibraryList.
712eab94f7dfd41a65e13aca379a1aed97447f8884jpadmanatypedef struct sub_effect_entry_s {
722eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana    lib_entry_t *lib;
732eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana    void *object;
742eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana} sub_effect_entry_t;
752eab94f7dfd41a65e13aca379a1aed97447f8884jpadmana
76f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana
77090eb09be1600b101b6d6e4e092f30763776bc80rago
78f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana////////////////////////////////////////////////////////////////////////////////
79f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//
80f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//    Function:       EffectGetSubEffects
81f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//
82f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//    Description:    Returns the descriptors of the sub effects of the effect
83f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//                    whose uuid is pointed to by first argument.
84f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//
85f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//    Input:
86f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//          pEffectUuid:    pointer to the effect uuid.
87f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//          size:           max number of sub_effect_entry_t * in pSube.
88f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//
89f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//    Input/Output:
90f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//          pSube:          address where to return the sub effect structures.
91f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//    Output:
92f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//        returned value:    0          successful operation.
93f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//                          -ENODEV     factory failed to initialize
94f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//                          -EINVAL     invalid pEffectUuid or pDescriptor
95f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//                          -ENOENT     no effect with this uuid found
96f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//        *pDescriptor:     updated with the sub effect descriptors.
97f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana//
98f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana////////////////////////////////////////////////////////////////////////////////
99f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmanaint EffectGetSubEffects(const effect_uuid_t *pEffectUuid,
100f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana                        sub_effect_entry_t **pSube,
101f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana                        size_t size);
102f90c7e0bb8d83d8b7f733bdf430d331ea3f221e8jpadmana
103135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent#if __cplusplus
104135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent}  // extern "C"
105135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent#endif
106135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
107135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent
108135ad07e33d30e5202deb21061a0e3ecf0ffad35Eric Laurent#endif /*ANDROID_EFFECTSFACTORY_H_*/
109