blob: 1764f5ef9beaf62db6f9df7d88b0b6c310b1b4ca [file] [log] [blame]
#include "aidl/android/hardware/gnss/SatellitePositionEcef.h"
#include <android/binder_parcel_utils.h>
namespace aidl {
namespace android {
namespace hardware {
namespace gnss {
const char* SatellitePositionEcef::descriptor = "android.hardware.gnss.SatellitePositionEcef";
binder_status_t SatellitePositionEcef::readFromParcel(const AParcel* parcel) {
int32_t _aidl_parcelable_size;
int32_t _aidl_start_pos = AParcel_getDataPosition(parcel);
binder_status_t _aidl_ret_status = AParcel_readInt32(parcel, &_aidl_parcelable_size);
if (_aidl_start_pos > INT32_MAX - _aidl_parcelable_size) return STATUS_BAD_VALUE;
if (_aidl_parcelable_size < 0) return STATUS_BAD_VALUE;
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
if (AParcel_getDataPosition(parcel) - _aidl_start_pos >= _aidl_parcelable_size) {
AParcel_setDataPosition(parcel, _aidl_start_pos + _aidl_parcelable_size);
return _aidl_ret_status;
}
_aidl_ret_status = AParcel_readDouble(parcel, &posXMeters);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
if (AParcel_getDataPosition(parcel) - _aidl_start_pos >= _aidl_parcelable_size) {
AParcel_setDataPosition(parcel, _aidl_start_pos + _aidl_parcelable_size);
return _aidl_ret_status;
}
_aidl_ret_status = AParcel_readDouble(parcel, &posYMeters);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
if (AParcel_getDataPosition(parcel) - _aidl_start_pos >= _aidl_parcelable_size) {
AParcel_setDataPosition(parcel, _aidl_start_pos + _aidl_parcelable_size);
return _aidl_ret_status;
}
_aidl_ret_status = AParcel_readDouble(parcel, &posZMeters);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
if (AParcel_getDataPosition(parcel) - _aidl_start_pos >= _aidl_parcelable_size) {
AParcel_setDataPosition(parcel, _aidl_start_pos + _aidl_parcelable_size);
return _aidl_ret_status;
}
_aidl_ret_status = AParcel_readDouble(parcel, &ureMeters);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
AParcel_setDataPosition(parcel, _aidl_start_pos + _aidl_parcelable_size);
return _aidl_ret_status;
}
binder_status_t SatellitePositionEcef::writeToParcel(AParcel* parcel) const {
binder_status_t _aidl_ret_status;
size_t _aidl_start_pos = AParcel_getDataPosition(parcel);
_aidl_ret_status = AParcel_writeInt32(parcel, 0);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
_aidl_ret_status = AParcel_writeDouble(parcel, posXMeters);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
_aidl_ret_status = AParcel_writeDouble(parcel, posYMeters);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
_aidl_ret_status = AParcel_writeDouble(parcel, posZMeters);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
_aidl_ret_status = AParcel_writeDouble(parcel, ureMeters);
if (_aidl_ret_status != STATUS_OK) return _aidl_ret_status;
size_t _aidl_end_pos = AParcel_getDataPosition(parcel);
AParcel_setDataPosition(parcel, _aidl_start_pos);
AParcel_writeInt32(parcel, _aidl_end_pos - _aidl_start_pos);
AParcel_setDataPosition(parcel, _aidl_end_pos);
return _aidl_ret_status;
}
} // namespace gnss
} // namespace hardware
} // namespace android
} // namespace aidl