| /* |
| * Copyright (C) 2010 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| /* LEDArray implementation */ |
| |
| #include "sles_allinclusive.h" |
| |
| |
| static SLresult ILEDArray_ActivateLEDArray(SLLEDArrayItf self, SLuint32 lightMask) |
| { |
| SL_ENTER_INTERFACE |
| |
| ILEDArray *thiz = (ILEDArray *) self; |
| interface_lock_poke(thiz); |
| thiz->mLightMask = lightMask; |
| interface_unlock_poke(thiz); |
| result = SL_RESULT_SUCCESS; |
| |
| SL_LEAVE_INTERFACE |
| } |
| |
| |
| static SLresult ILEDArray_IsLEDArrayActivated(SLLEDArrayItf self, SLuint32 *pLightMask) |
| { |
| SL_ENTER_INTERFACE |
| |
| if (NULL == pLightMask) { |
| result = SL_RESULT_PARAMETER_INVALID; |
| } else { |
| ILEDArray *thiz = (ILEDArray *) self; |
| interface_lock_peek(thiz); |
| SLuint32 lightMask = thiz->mLightMask; |
| interface_unlock_peek(thiz); |
| *pLightMask = lightMask; |
| result = SL_RESULT_SUCCESS; |
| } |
| |
| SL_LEAVE_INTERFACE |
| } |
| |
| |
| static SLresult ILEDArray_SetColor(SLLEDArrayItf self, SLuint8 index, const SLHSL *pColor) |
| { |
| SL_ENTER_INTERFACE |
| |
| result = SL_RESULT_PARAMETER_INVALID; |
| do { |
| if (!(index < MAX_LED_COUNT) || NULL == pColor) |
| break; |
| SLHSL color = *pColor; |
| if (!(0 <= color.hue && color.hue <= 360000)) |
| break; |
| if (!(0 <= color.saturation && color.saturation <= 1000)) |
| break; |
| if (!(0 <= color.lightness && color.lightness <= 1000)) |
| break; |
| ILEDArray *thiz = (ILEDArray *) self; |
| // can't use poke because struct copy might not be atomic |
| interface_lock_exclusive(thiz); |
| thiz->mColors[index] = color; |
| interface_unlock_exclusive(thiz); |
| result = SL_RESULT_SUCCESS; |
| } while (0); |
| |
| SL_LEAVE_INTERFACE |
| } |
| |
| |
| static SLresult ILEDArray_GetColor(SLLEDArrayItf self, SLuint8 index, SLHSL *pColor) |
| { |
| SL_ENTER_INTERFACE |
| |
| if (!(index < MAX_LED_COUNT) || NULL == pColor) { |
| result = SL_RESULT_PARAMETER_INVALID; |
| } else { |
| ILEDArray *thiz = (ILEDArray *) self; |
| // can't use peek because struct copy might not be atomic |
| interface_lock_shared(thiz); |
| SLHSL color = thiz->mColors[index]; |
| interface_unlock_shared(thiz); |
| *pColor = color; |
| result = SL_RESULT_SUCCESS; |
| } |
| |
| SL_LEAVE_INTERFACE |
| } |
| |
| |
| static const struct SLLEDArrayItf_ ILEDArray_Itf = { |
| ILEDArray_ActivateLEDArray, |
| ILEDArray_IsLEDArrayActivated, |
| ILEDArray_SetColor, |
| ILEDArray_GetColor |
| }; |
| |
| void ILEDArray_init(void *self) |
| { |
| ILEDArray *thiz = (ILEDArray *) self; |
| thiz->mItf = &ILEDArray_Itf; |
| thiz->mLightMask = 0; |
| SLHSL *color = thiz->mColors; |
| SLuint8 index; |
| for (index = 0; index < MAX_LED_COUNT; ++index, ++color) { |
| color->hue = 0; // red, but per specification 1.0.1 pg. 259: "Default color is undefined." |
| color->saturation = 1000; |
| color->lightness = 1000; |
| } |
| // const |
| thiz->mCount = MAX_LED_COUNT; |
| } |