16fd81a51SAndrew Jeffery# Changelog 26fd81a51SAndrew Jeffery 36fd81a51SAndrew JefferyAll notable changes to this project will be documented in this file. 46fd81a51SAndrew Jeffery 56fd81a51SAndrew JefferyThe format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), 66fd81a51SAndrew Jefferyand this project adheres to 76fd81a51SAndrew Jeffery[Semantic Versioning](https://semver.org/spec/v2.0.0.html). 86fd81a51SAndrew Jeffery 96fd81a51SAndrew JefferyChange categories: 106fd81a51SAndrew Jeffery 116fd81a51SAndrew Jeffery- Added 126fd81a51SAndrew Jeffery- Changed 136fd81a51SAndrew Jeffery- Deprecated 146fd81a51SAndrew Jeffery- Removed 156fd81a51SAndrew Jeffery- Fixed 166fd81a51SAndrew Jeffery- Security 176fd81a51SAndrew Jeffery 181be1d5eaSAndrew Jeffery## [Unreleased] 191be1d5eaSAndrew Jeffery 20309a5cdeSAndrew Jeffery### Added 21309a5cdeSAndrew Jeffery 22309a5cdeSAndrew Jeffery1. dsp: firmware_update: Iterators for downstream device descriptors 2330b25645SThu Nguyen2. platform: add PLDM Command numbers 2435b72d95SThu Nguyen3. base: add PLDM Command numbers 25309a5cdeSAndrew Jeffery 261be1d5eaSAndrew Jeffery### Changed 271be1d5eaSAndrew Jeffery 281be1d5eaSAndrew Jeffery1. Register assignment for parameters of `encode_state_effecter_pdr()` 291be1d5eaSAndrew Jeffery 30309a5cdeSAndrew Jeffery2. dsp: firmware_update: Iterators for downstream device descriptors 31309a5cdeSAndrew Jeffery 32309a5cdeSAndrew Jeffery The prototype for `decode_query_downstream_identifiers_resp()` was updated to 33309a5cdeSAndrew Jeffery improve ergonomics for the iterator APIs. 34309a5cdeSAndrew Jeffery 35*fef24ed6SAndrew Jeffery3. meson: Specify OEM extensions in an array 36*fef24ed6SAndrew Jeffery 37*fef24ed6SAndrew Jeffery `include/libpldm/meson.build` is modified, but not in ways that are 38*fef24ed6SAndrew Jeffery significant. 39*fef24ed6SAndrew Jeffery 401be1d5eaSAndrew Jeffery### Fixed 411be1d5eaSAndrew Jeffery 421be1d5eaSAndrew Jeffery1. dsp: platform: Fix location of closing paren in overflow detection 43309a5cdeSAndrew Jeffery2. libpldm: Install api header, update changelog 441be1d5eaSAndrew Jeffery 455d8e30ccSAndrew Jeffery## [0.10.0] 2024-11-01 46ff2f4214SAndrew Jeffery 470f5be28fSLora Lin### Added 480f5be28fSLora Lin 490f5be28fSLora Lin1. oem: meta: Add decode_oem_meta_file_io_write_req() 50893a08f0SLora Lin2. oem: meta: Add decode_oem_meta_file_io_read_req() 516476c968SLora Lin3. oem: meta: Add encode_oem_meta_file_io_read_resp() 52b31e4c6cSVarsha Kaverappa4. pdr: Add pldm_entity_association_pdr_remove_contained_entity() 538b53ad9dSVarsha Kaverappa5. pdr: Add pldm_pdr_remove_fru_record_set_by_rsi() 5460582150SAndrew Jeffery6. pldm_entity_association_tree_copy_root_check() 553f877481SPavithra Barithaya7. oem: ibm: Add topology related state set and enum 560f5be28fSLora Lin 57387b10f6SThu Nguyen8. base: Add size and buffer macros for struct pldm_msg 587a3c14ecSAndrew Jeffery 597a3c14ecSAndrew Jeffery Together these macros reduce the need for use of reinterpret_cast<>() in C++. 607a3c14ecSAndrew Jeffery 61654eb966SManojkiran Eda9. entity: Add new entity types from DSP0249 v1.3.0 628e23fd04SManojkiran Eda10. stateset: Add new state sets from DSP0249 v1.3.0 63654eb966SManojkiran Eda 643b5ab929SAndrew Jeffery### Changed 653b5ab929SAndrew Jeffery 663b5ab929SAndrew Jeffery1. dsp: bios_table: Null check for pldm_bios_table_iter_is_end() 673b5ab929SAndrew Jeffery 683b5ab929SAndrew Jeffery pldm_bios_table_iter_is_end() now returns true if the provided argument is 693b5ab929SAndrew Jeffery NULL. 703b5ab929SAndrew Jeffery 714f60fb77SAndrew Jeffery2. Register assignment for parameters of a number of APIs changed with increased 724f60fb77SAndrew Jeffery scrutiny on their implementations. 73830c1eb4SAndrew Jeffery 74830c1eb4SAndrew Jeffery - `decode_entity_auxiliary_names_pdr()` 75830c1eb4SAndrew Jeffery - `decode_get_state_sensor_readings_resp()` 7636324f6bSAndrew Jeffery - `decode_oem_meta_file_io_req()` 77830c1eb4SAndrew Jeffery - `decode_platform_event_message_req()` 78830c1eb4SAndrew Jeffery - `decode_platform_event_message_resp()` 79830c1eb4SAndrew Jeffery - `decode_sensor_op_data()` 80830c1eb4SAndrew Jeffery - `encode_get_state_effecter_states_resp()` 81ad33b99aSAndrew Jeffery - `encode_state_effecter_pdr()` 82bb50a590SAndrew Jeffery - `encode_state_sensor_pdr()` 83d610b00eSAndrew Jeffery - `pldm_bios_table_append_pad_checksum()` 8492967bedSAndrew Jeffery - `pldm_bios_table_attr_value_entry_encode_enum()` 85d96d21f4SAndrew Jeffery - `pldm_bios_table_attr_value_entry_encode_string()` 864f60fb77SAndrew Jeffery - `pldm_pdr_find_record()` 874f60fb77SAndrew Jeffery - `pldm_pdr_get_next_record()` 884f60fb77SAndrew Jeffery 894f60fb77SAndrew Jeffery3. platform: Support PLDM_CPER_EVENT in encode_platform_event_message_req() 90830c1eb4SAndrew Jeffery 91a9892499SAndrew Jeffery4. dsp: firmware_update: Bounds check 92a9892499SAndrew Jeffery decode_downstream_device_parameter_table_entry_versions() 93a9892499SAndrew Jeffery 94a9892499SAndrew Jeffery The additional bounds-checking required the addition of further length 95a9892499SAndrew Jeffery parameters. 96a9892499SAndrew Jeffery 970f5be28fSLora Lin### Deprecated 980f5be28fSLora Lin 990f5be28fSLora Lin1. oem: meta: Deprecate `decode_oem_meta_file_io_req()` 1000f5be28fSLora Lin 1010f5be28fSLora Lin Users should switch to `decode_oem_meta_file_io_write_req()`. Modify this 1020f5be28fSLora Lin function to make it safer. 1030f5be28fSLora Lin 1040f5be28fSLora Lin Modification: 1050f5be28fSLora Lin 1060f5be28fSLora Lin - The meaning of the returned result. 1070f5be28fSLora Lin - Change parameters from individual pointers to a struct. 1080f5be28fSLora Lin - Check the length provided in the message won't exceed the buffer. 1090f5be28fSLora Lin 11060582150SAndrew Jeffery2. pldm_entity_association_tree_copy_root() 11160582150SAndrew Jeffery 11260582150SAndrew Jeffery The implementation allocates, but gives no indication to the caller if an 11360582150SAndrew Jeffery allocation (and hence the copy) has failed. Users should migrate to 11460582150SAndrew Jeffery pldm_entity_association_tree_copy_root_check(). 11560582150SAndrew Jeffery 11636324f6bSAndrew Jeffery3. The following APIs are deprecated as unsafe due to various unfixable CWE 11736324f6bSAndrew Jeffery violations: 11836324f6bSAndrew Jeffery 11936324f6bSAndrew Jeffery - [CWE-129: Improper Validation of Array Index](https://cwe.mitre.org/data/definitions/129.html) 12036324f6bSAndrew Jeffery 12136324f6bSAndrew Jeffery - `encode_get_bios_current_value_by_handle_resp()` 12236324f6bSAndrew Jeffery - `encode_get_bios_table_resp()` 12336324f6bSAndrew Jeffery - `encode_get_file_table_resp()` 12436324f6bSAndrew Jeffery - `encode_get_version_resp()` 12536324f6bSAndrew Jeffery - `pldm_bios_table_attr_entry_enum_decode_def_indices()` 12636324f6bSAndrew Jeffery - `pldm_bios_table_attr_entry_enum_decode_def_num()` 12736324f6bSAndrew Jeffery - `pldm_bios_table_attr_find_by_handle()` 12836324f6bSAndrew Jeffery - `pldm_bios_table_attr_find_by_string_handle()` 12936324f6bSAndrew Jeffery - `pldm_bios_table_attr_value_find_by_handle()` 13036324f6bSAndrew Jeffery - `pldm_bios_table_iter_create()` 13136324f6bSAndrew Jeffery - `pldm_bios_table_iter_is_end()` 13236324f6bSAndrew Jeffery - `pldm_bios_table_string_find_by_handle()` 13336324f6bSAndrew Jeffery - `pldm_bios_table_string_find_by_string()` 13436324f6bSAndrew Jeffery 13536324f6bSAndrew Jeffery - [CWE-617: Reachable Assertion](https://cwe.mitre.org/data/definitions/617.html) 13636324f6bSAndrew Jeffery 13736324f6bSAndrew Jeffery - `pldm_entity_association_tree_copy_root()` 13836324f6bSAndrew Jeffery 13936324f6bSAndrew Jeffery - [CWE-789: Memory Allocation with Excessive Size Value](https://cwe.mitre.org/data/definitions/789.html) 14036324f6bSAndrew Jeffery 14136324f6bSAndrew Jeffery - `decode_oem_meta_file_io_req()` 14236324f6bSAndrew Jeffery 14336324f6bSAndrew Jeffery - [CWE-823: Use of Out-of-range Pointer Offset](https://cwe.mitre.org/data/definitions/823.html) 14436324f6bSAndrew Jeffery - `encode_fru_record()` 14536324f6bSAndrew Jeffery - `encode_get_pdr_resp()` 14636324f6bSAndrew Jeffery - `pldm_bios_table_attr_entry_enum_encode_length()` 14736324f6bSAndrew Jeffery 148ff2f4214SAndrew Jeffery### Removed 149ff2f4214SAndrew Jeffery 150eb9df78bSAndrew Jeffery1. Deprecated functions with the `_check` suffix 151eb9df78bSAndrew Jeffery 1524e672656SAndrew Jeffery - `get_fru_record_by_option_check()` 153eb9df78bSAndrew Jeffery - `pldm_bios_table_append_pad_checksum_check()` 154eb9df78bSAndrew Jeffery - `pldm_bios_table_attr_entry_enum_decode_def_num_check()` 15507fdf2d8SAndrew Jeffery - `pldm_bios_table_attr_entry_enum_decode_pv_hdls_check()` 15603aa3d6cSAndrew Jeffery - `pldm_bios_table_attr_entry_enum_decode_pv_num_check()` 15783a208afSAndrew Jeffery - `pldm_bios_table_attr_entry_enum_encode_check()` 158f5c63dfdSAndrew Jeffery - `pldm_bios_table_attr_entry_integer_encode_check()` 1594d8634d7SAndrew Jeffery - `pldm_bios_table_attr_entry_string_decode_def_string_length_check()` 1605f288563SAndrew Jeffery - `pldm_bios_table_attr_entry_string_encode_check()` 1612170655aSAndrew Jeffery - `pldm_bios_table_attr_value_entry_encode_enum_check()` 1625a8b7c54SAndrew Jeffery - `pldm_bios_table_attr_value_entry_encode_integer_check()` 163de926829SAndrew Jeffery - `pldm_bios_table_attr_value_entry_encode_string_check()` 1641085e232SAndrew Jeffery - `pldm_bios_table_string_entry_decode_string_check()` 165c79375dfSAndrew Jeffery - `pldm_bios_table_string_entry_encode_check()` 16638004f7aSAndrew Jeffery - `pldm_entity_association_pdr_add_check()` 16773a2f66eSAndrew Jeffery - `pldm_entity_association_pdr_add_from_node_check()` 168f309c48dSAndrew Jeffery - `pldm_pdr_add_check()` 169453dfff3SAndrew Jeffery - `pldm_pdr_add_fru_record_set_check()` 170ff2f4214SAndrew Jeffery 1713b5ab929SAndrew Jeffery### Fixed 1723b5ab929SAndrew Jeffery 1733b5ab929SAndrew Jeffery1. dsp: bios_table: Null check for pldm_bios_table_iter_is_end() 1743b5ab929SAndrew Jeffery 1753b5ab929SAndrew Jeffery Avoid a caller-controlled NULL pointer dereference in the library 1763b5ab929SAndrew Jeffery implementation. 1773b5ab929SAndrew Jeffery 178387b10f6SThu Nguyen2. platform: fix encode/decode_poll_for_platform_event_message_req 179387b10f6SThu Nguyen 180387b10f6SThu Nguyen Update checking of `TransferOperationFlag` and `eventIDToAcknowledge` to 181387b10f6SThu Nguyen follow spec. 182387b10f6SThu Nguyen 1839e16b18bSThu Nguyen3. platform: Fix checking `eventIDToAcknowledge` 1849e16b18bSThu Nguyen 1859e16b18bSThu Nguyen As the event receiver sends `PollForPlatformEventMessage` with the 1869e16b18bSThu Nguyen `tranferFlag` is `AcknowledgementOnly`, the value `eventIDToAcknowledge` 1879e16b18bSThu Nguyen should be the previously retrieved eventID (from the PLDM terminus). 1889e16b18bSThu Nguyen 189225530abSAndrew Jeffery4. dsp: platform: Prevent overflow of arithmetic on event_data_length 190bb50a590SAndrew Jeffery5. dsp: platform: Bounds check encode_sensor_state_pdr() 191ad33b99aSAndrew Jeffery6. dsp: platform: Bounds check encode_state_effecter_pdr() 1929e566597SAndrew Jeffery7. dsp: pdr: Bounds check pldm_entity_association_pdr_extract() 193d610b00eSAndrew Jeffery8. dsp: bios_table: Bounds check pldm_bios_table_append_pad_checksum() 194d96d21f4SAndrew Jeffery9. dsp: bios_table: Bounds check 195d96d21f4SAndrew Jeffery pldm_bios_table_attr_value_entry_encode_string() 19692967bedSAndrew Jeffery10. dsp: bios_table: Bounds check pldm_bios_table_attr_value_entry_encode_enum() 197a9892499SAndrew Jeffery11. dsp: firmware_update: Bounds check 198a9892499SAndrew Jeffery decode_downstream_device_parameter_table_entry_versions() 19957d9a2efSAndrew Jeffery12. oem: ibm: platform: Bounds check encode_bios_attribute_update_event_req() 20082c34815SAndrew Jeffery13. dsp: fru: Bounds check encode_get_fru_record_by_option_resp() 201d7d08f65SAndrew Jeffery14. dsp: fru: Bounds check encode_fru_record() 20237016fefSAndrew Jeffery15. dsp: bios: Bounds check encode_set_bios_table_req() 2033b33c135SAndrew Jeffery16. dsp: bios: Bounds check encode_set_bios_attribute_current_value_req() 20421cb052bSAndrew Jeffery17. dsp: bios_table: Bounds check pldm_bios_table_string_entry_encode() 2058f33a1dcSAndrew Jeffery18. dsp: pdr: Rework test in pldm_entity_association_pdr_extract() 20698e137deSGilbert Chen19. dsp: platform: Fix decode_set_event_receiver_req() 207225530abSAndrew Jeffery 208615344fcSAndrew Jeffery## [0.9.1] - 2024-09-07 209615344fcSAndrew Jeffery 210615344fcSAndrew Jeffery### Changed 211615344fcSAndrew Jeffery 212615344fcSAndrew Jeffery1. Moved evolutions intended for v0.9.0 into place 213615344fcSAndrew Jeffery 214615344fcSAndrew Jeffery Evolutions for the release have been moved from `evolutions/current` to 215615344fcSAndrew Jeffery `evolutions/v0.9.1`. Library users can apply them to migrate off of 216615344fcSAndrew Jeffery deprecated APIs. 21739f88325SRashmica Gupta 218747a498eSAndrew Jeffery## [0.9.0] - 2024-09-07 219747a498eSAndrew Jeffery 2200ee03b5bSThu Nguyen### Added 2210ee03b5bSThu Nguyen 2220ee03b5bSThu Nguyen1. base: Define macros for reserved TIDs 223b02e0e11SVarsha Kaverappa2. pdr: Add pldm_entity_association_pdr_add_contained_entity_to_remote_pdr() 224b02e0e11SVarsha Kaverappa3. pdr: Add pldm_entity_association_pdr_create_new() 225e5469f54SThu Nguyen4. platform: Define macros for the responded transferflags 226274732fcSPavithra Barithaya5. pdr: Add pldm_pdr_get_terminus_handle() API 227dacfa354SThu Nguyen6. pdr: Add related decode_entity_auxiliary_names_pdr() APIs 228b6ef35b4SChris Wang7. fw_update: Add encode req & decode resp for get_downstream_fw_params 22902903038SThu Nguyen8. platform: Add decode_pldm_platform_cper_event() API 2300a1be3cbSAndrew Jeffery9. decode_get_pdr_repository_info_resp_safe() 2310a1be3cbSAndrew Jeffery 2320a1be3cbSAndrew Jeffery Replaces decode_get_pdr_repository_info_resp() as discussed in the 2330a1be3cbSAndrew Jeffery `Deprecated` section below 2340a1be3cbSAndrew Jeffery 2350a1be3cbSAndrew Jeffery10. decode_get_pdr_resp_safe() 2360a1be3cbSAndrew Jeffery 2370a1be3cbSAndrew Jeffery Replaces decode_get_pdr_resp() as discussed in the `Deprecated` section 2380a1be3cbSAndrew Jeffery below 2390ee03b5bSThu Nguyen 24043cb4b5fSThu Nguyen### Changed 24143cb4b5fSThu Nguyen 24243cb4b5fSThu Nguyen1. pdr: Stabilise related decode_entity_auxiliary_names_pdr() APIs 2437739d123SThu Nguyen2. platform: Rework decode/encode_pldm_message_poll_event_data() APIs 244f874b383SThu Nguyen3. platform: Stabilise decode_pldm_message_poll_event_data() APIs 24590bbe6c0SAndrew Jeffery4. ABI break for decode_sensor_op_data() 24690bbe6c0SAndrew Jeffery 24790bbe6c0SAndrew Jeffery Applying LIBPLDM_CC_NONNULL to the internal msgbuf APIs caused 24890bbe6c0SAndrew Jeffery abi-compliance-checker to flag a change in the register containing the 24990bbe6c0SAndrew Jeffery parameter `previous_op_state`. 25043cb4b5fSThu Nguyen 2513559aa1fSThu Nguyen5. platform: Stabilise decode_pldm_platform_cper_event() API 252ea0bf3a8SLora Lin6. oem: meta: Stabilise decode_oem_meta_file_io_write_req() API 253ea0bf3a8SLora Lin7. oem: meta: Stabilise decode_oem_meta_file_io_read_req() API 254ea0bf3a8SLora Lin8. oem: meta: Stabilise encode_oem_meta_file_io_read_resp() API 2553559aa1fSThu Nguyen 256d9b70ba7SAndrew Jeffery### Deprecated 257d9b70ba7SAndrew Jeffery 258e7f55113SAndrew Jeffery1. Rename and deprecate functions with the `_check` suffix 259d9b70ba7SAndrew Jeffery 260e7f55113SAndrew Jeffery All library function return values always need to be checked. The `_check` 261e7f55113SAndrew Jeffery suffix is redundant, so remove it. Migration to the non-deprecated 262e7f55113SAndrew Jeffery equivalents without the `_check` suffix can be performed using 263e7f55113SAndrew Jeffery `scripts/ apply-renames` and the [clang-rename][] configurations under 264e7f55113SAndrew Jeffery `evolutions/` 265d9b70ba7SAndrew Jeffery 266e7f55113SAndrew Jeffery The deprecated functions: 267e7f55113SAndrew Jeffery 268e7f55113SAndrew Jeffery - `get_fru_record_by_option_check()` 269d8bb75cbSAndrew Jeffery - `pldm_bios_table_append_pad_checksum_check()` 27046673f4aSAndrew Jeffery - `pldm_bios_table_attr_entry_enum_decode_def_num_check()` 27182b4d3b4SAndrew Jeffery - `pldm_bios_table_attr_entry_enum_decode_pv_hdls_check()` 272b06882f1SAndrew Jeffery - `pldm_bios_table_attr_entry_enum_decode_pv_num_check()` 2737126b1d2SAndrew Jeffery - `pldm_bios_table_attr_entry_enum_encode_check()` 2745347e279SAndrew Jeffery - `pldm_bios_table_attr_entry_integer_encode_check()` 275c668ffceSAndrew Jeffery - `pldm_bios_table_attr_entry_string_decode_def_string_length_check()` 276f6be4933SAndrew Jeffery - `pldm_bios_table_attr_entry_string_encode_check()` 27709004d6aSAndrew Jeffery - `pldm_bios_table_attr_value_entry_encode_enum_check()` 278504dd17fSAndrew Jeffery - `pldm_bios_table_attr_value_entry_encode_integer_check()` 2791a3983ceSAndrew Jeffery - `pldm_bios_table_attr_value_entry_encode_string_check()` 2808c37ab36SAndrew Jeffery - `pldm_bios_table_string_entry_decode_string_check()` 281e48fdd6eSAndrew Jeffery - `pldm_bios_table_string_entry_encode_check()` 282d72ea4b8SAndrew Jeffery - `pldm_entity_association_pdr_add_check()` 283aa49b71fSAndrew Jeffery - `pldm_entity_association_pdr_add_from_node_check()` 284e7f55113SAndrew Jeffery - `pldm_pdr_add_check()` 285e7f55113SAndrew Jeffery - `pldm_pdr_add_fru_record_set_check()` 286d9b70ba7SAndrew Jeffery 287acb0681dSAndrew Jeffery[clang-rename]: https://clang.llvm.org/extra/clang-rename.html 288d9b70ba7SAndrew Jeffery 2890a1be3cbSAndrew Jeffery2. `decode_get_pdr_repository_info_resp()` 2900a1be3cbSAndrew Jeffery 2910a1be3cbSAndrew Jeffery Users should move to `decode_get_pdr_repository_info_resp_safe()` which 2920a1be3cbSAndrew Jeffery eliminates the opportunity for buffer overruns when extracting objects from 2930a1be3cbSAndrew Jeffery the message. 2940a1be3cbSAndrew Jeffery 2950a1be3cbSAndrew Jeffery3. `decode_get_pdr_resp()` 2960a1be3cbSAndrew Jeffery 2970a1be3cbSAndrew Jeffery Users should move to `decode_get_pdr_resp_safe()` which reduces the 2980a1be3cbSAndrew Jeffery invocation tedium and improves memory safety over `decode_get_pdr_resp()`. 2990a1be3cbSAndrew Jeffery 300a1efaa2eSAndrew Jeffery### Removed 301a1efaa2eSAndrew Jeffery 302a1efaa2eSAndrew Jeffery1. IBM OEM header compatibility symlinks. 303a1efaa2eSAndrew Jeffery 304a1efaa2eSAndrew Jeffery Anyone left using the deprecated paths can migrate using the coccinelle patch 305a1efaa2eSAndrew Jeffery at `evolutions/current/oem-ibm-header-compat.cocci`. 306a1efaa2eSAndrew Jeffery 307e4240679SAndrew Jeffery### Fixed 308e4240679SAndrew Jeffery 309e4240679SAndrew Jeffery1. requester: instance-id: Release read lock on conflict 31074c9a546SArchana Kakani2. pdr: Error propagation for 31174c9a546SArchana Kakani pldm_entity_association_pdr_add_from_node_with_record_handle() 312e4240679SAndrew Jeffery 313c166dd5fSAndrew Jeffery## [0.8.0] - 2024-05-23 314c166dd5fSAndrew Jeffery 315acf22454SAndrew Jeffery### Added 316acf22454SAndrew Jeffery 317acf22454SAndrew Jeffery1. base: Provide pldm_msg_hdr_correlate_response() 318acf22454SAndrew Jeffery2. transport: af-mctp: Add pldm_transport_af_mctp_bind() 319499389ecSKamalkumar Patel3. oem: ibm: Add chapdata file type support 3206967fc73SManojkiran Eda4. base: Added PLDM_SMBIOS & PLDM_RDE message types 32122fad395SDelphine CC Chiu5. oem: meta: Add decode_oem_meta_file_io_req() 32239aa036eSVarsha Kaverappa6. state-set: Add all state set values to system power state enum as per DSP0249 3230ee77664SVarsha Kaverappa7. platform: Add alias members to the enum 3240ee77664SVarsha Kaverappa pldm_pdr_repository_chg_event_change_record_event_data_operation. 3250ee77664SVarsha Kaverappa 3260ee77664SVarsha Kaverappa enum constants with inconsistent names are deprecated with this change. 3270ee77664SVarsha Kaverappa remove old inconsistent enum members after backward compatibility cleanup is 3280ee77664SVarsha Kaverappa done 329acf22454SAndrew Jeffery 330a9f2ffd4SPavithra Barithaya8. oem-ibm: Alias `pldm_oem_ibm_fru_field_type` members as `PLDM_OEM_IBM_*` 331819f138aSPavithra Barithaya9. oem: ibm: Add Firmware Update Access Key(UAK) as a FRU field type 33264764fd6SJinliang Wang10. platform: Add 3 PDR type enum for Redfish Device Enablement per 33364764fd6SJinliang Wang DSP0248_1.2.0 33464764fd6SJinliang Wang11. state_set: Add CONNECTED and DISCONNECTED enum for Link State set 33564764fd6SJinliang Wang12. entity: Add enum for Network Interface Connectors and Network Ports 33664764fd6SJinliang Wang Connection Types 337d4878cdfSThu Nguyen13. pdr: Add decode_numeric_effecter_pdr_data() 338ea435c9fSJayashankar Padath14. oem: ibm: Support for the Real SAI entity id 3394c1f2c72SChris Wang15. fw_update: Add encode req & decode resp for query_downstream_devices 340458475a9SChris Wang16. fw_update: Add encode req & decode resp for query_downstream_identifiers 341a6fa5559STal Yacobi17. platform: Add support for GetStateEffecterStates command 342a9f2ffd4SPavithra Barithaya 343acf22454SAndrew Jeffery### Changed 344acf22454SAndrew Jeffery 345acf22454SAndrew Jeffery1. base: Stabilise pldm_msg_hdr_correlate_response() 346acf22454SAndrew Jeffery2. transport: af-mctp: Stabilise pldm_transport_af_mctp_bind() 347b0c1d20aSAndrew Jeffery3. libpldm: Fix header use 348efb40069SAndrew Jeffery4. libpldm: More fixes for header use 3494a307bcaSPavithra Barithaya5. pdr: Stabilise pldm_pdr_find_last_in_range() API 3503a267059SPavithra Barithaya6. pdr: Stabilise pldm_entity_association_pdr_add_from_node_with_record_handle() 351a98814fcSAndrew Jeffery7. oem: meta: stabilise decode_oem_meta_file_io_req() 352c6c391d6SGeorge Liu8. pdr: pldm_entity_association_tree_copy_root(): Document preconditions 353acf22454SAndrew Jeffery 354a9f2ffd4SPavithra Barithaya### Deprecated 355a9f2ffd4SPavithra Barithaya 356a9f2ffd4SPavithra Barithaya1. Deprecate `pldm_oem_ibm_fru_field_type` members that that are not prefixed 357a9f2ffd4SPavithra Barithaya with `PLDM_OEM_IBM_` 358a9f2ffd4SPavithra Barithaya 359d12dd36eSAndrew Jeffery### Fixed 360d12dd36eSAndrew Jeffery 361d12dd36eSAndrew Jeffery1. libpldm: Rationalise the local and installed path of pldm.h 36239eb3224SPavithra Barithaya2. pdr: Assign record_handle in entity_association_pdr_add_children() 363cd07fec7SThu Nguyen3. msgbuf: Require sensor data enum in pldm_msgbuf_extract_sensor_value() 36451230a0aSThu Nguyen4. pdr: Remove redundant constant for minimum numeric sensor PDR length 36532df16c4SAndrew Jeffery5. tests: oem: meta: Fix fileio use of msgbuf 366d12dd36eSAndrew Jeffery 3673f39f963SAndrew Jeffery## [0.7.0] - 2023-08-29 3683f39f963SAndrew Jeffery 369f37e4dc8SPavithra Barithaya### Added 370f37e4dc8SPavithra Barithaya 371f37e4dc8SPavithra Barithaya1. state-set: Add new enum for Operational Fault Status enum 3726c835a14SAndrew Jeffery 3736c835a14SAndrew Jeffery### Changed 3746c835a14SAndrew Jeffery 3756c835a14SAndrew Jeffery1. transport: Match specified metadata in pldm_transport_send_recv_msg() 37645816b89SAndrew Jeffery2. transport: mctp-demux: Drop ABI annotation for internal symbols 3770a6d6821SAndrew Jeffery3. transport: Stabilise core transport and implementation APIs 3780a6d6821SAndrew Jeffery 3790a6d6821SAndrew Jeffery This stabilisation covers the following headers and functions: 3800a6d6821SAndrew Jeffery 3810a6d6821SAndrew Jeffery - libpldm/transport.h 3820a6d6821SAndrew Jeffery 3830a6d6821SAndrew Jeffery - pldm_transport_poll() 3840a6d6821SAndrew Jeffery - pldm_transport_send_msg() 3850a6d6821SAndrew Jeffery - pldm_transport_recv_msg() 3860a6d6821SAndrew Jeffery - pldm_transport_send_recv_msg() 3870a6d6821SAndrew Jeffery 3880a6d6821SAndrew Jeffery - libpldm/transport/af-mctp.h 3890a6d6821SAndrew Jeffery 3900a6d6821SAndrew Jeffery - pldm_transport_af_mctp_init() 3910a6d6821SAndrew Jeffery - pldm_transport_af_mctp_destroy() 3920a6d6821SAndrew Jeffery - pldm_transport_af_mctp_core() 3930a6d6821SAndrew Jeffery - pldm_transport_af_mctp_init_pollfd() 3940a6d6821SAndrew Jeffery - pldm_transport_af_mctp_map_tid() 3950a6d6821SAndrew Jeffery - pldm_transport_af_mctp_unmap_tid() 3960a6d6821SAndrew Jeffery 3970a6d6821SAndrew Jeffery - libpldm/transport/mctp-demux.h 3980a6d6821SAndrew Jeffery - pldm_transport_mctp_demux_init() 3990a6d6821SAndrew Jeffery - pldm_transport_mctp_demux_destroy() 4000a6d6821SAndrew Jeffery - pldm_transport_mctp_demux_core() 4010a6d6821SAndrew Jeffery - pldm_transport_mctp_demux_init_pollfd() 4020a6d6821SAndrew Jeffery - pldm_transport_mctp_demux_map_tid() 4030a6d6821SAndrew Jeffery - pldm_transport_mctp_demux_unmap_tid() 4040a6d6821SAndrew Jeffery 4050a6d6821SAndrew Jeffery### Deprecated 4060a6d6821SAndrew Jeffery 4070a6d6821SAndrew Jeffery1. All the existing "requester" APIs from `libpldm/pldm.h` (also known as 4080a6d6821SAndrew Jeffery `libpldm/requester/pldm.h`): 4090a6d6821SAndrew Jeffery 4100a6d6821SAndrew Jeffery - pldm_open() 4110a6d6821SAndrew Jeffery - pldm_send_recv() 4120a6d6821SAndrew Jeffery - pldm_send() 4130a6d6821SAndrew Jeffery - pldm_recv() 4140a6d6821SAndrew Jeffery - pldm_recv_any() 4150a6d6821SAndrew Jeffery - pldm_close() 4160a6d6821SAndrew Jeffery 4170a6d6821SAndrew Jeffery Users should migrate to the newer "transport" APIs instead. 418f37e4dc8SPavithra Barithaya 419ba05dba7SAndrew Jeffery## Fixed 420ba05dba7SAndrew Jeffery 421ba05dba7SAndrew Jeffery1. tests: Exclude transport tests when build excludes testing ABIs 42234ac891fSAndrew Jeffery2. abi: Capture deprecation of pldm_close() 423ba05dba7SAndrew Jeffery 424d2a36a16SAndrew Jeffery## [0.6.0] - 2023-08-22 425d2a36a16SAndrew Jeffery 4267062382aSAndrew Jeffery### Changed 4277062382aSAndrew Jeffery 4287062382aSAndrew Jeffery1. pdr: Avoid ID overflow in pldm_entity_association_tree_add_entity() 4295cf32ea8SAndrew Jeffery2. meson: Apply `b_ndebug=if-release` by default 430e7eebe33SAndrew Jeffery3. pdr : Stabilize pldm_entity_association_tree_add_entity() 43175ce90a5SAndrew Jeffery4. pdr: Stabilise pldm_entity_association_tree_find_with_locality() 432def8e024SPavithra Barithaya5. pdr: Stabilize pldm_entity_node_get_remote_container_id() 433ac24737cSAndrew Jeffery6. transport: af-mctp: Assign out-params on success in \*\_recv() 43424576290SRashmica Gupta7. transport: Generalise the pldm_transport_recv_msg() API 4357062382aSAndrew Jeffery 436255f6549SAndrew Jeffery### Removed 437255f6549SAndrew Jeffery 438255f6549SAndrew Jeffery1. pdr: Remove pldm_entity_association_pdr_add() 4397e3c9e4dSPavithra Barithaya2. state-set: Remove enum pldm_state_set_operational_fault_status_values 440255f6549SAndrew Jeffery 441b4cd5172SDelphine CC Chiu### Fixed 442b4cd5172SDelphine CC Chiu 443b4cd5172SDelphine CC Chiu1. transport: register init_pollfd callback for af-mctp 44436402ffbSBonnieLo-wiwynn2. transport: fix init_pollfd function parameter 445f1ebde49SRashmica Gupta3. transport: Fix doxygen and variables for send and recv functions 4467caa8af1SAndrew Jeffery4. transport: af-mctp: Ensure malloc() succeeds in \*\_recv() 447b4cd5172SDelphine CC Chiu 44820cc060cSAndrew Jeffery## [0.5.0] - 2023-08-09 44920cc060cSAndrew Jeffery 45065945992SAndrew Jeffery### Added 45165945992SAndrew Jeffery 45265945992SAndrew Jeffery1. pdr: Introduce pldm_entity_association_pdr_add_check() 45365945992SAndrew Jeffery 4543b93d09cSAndrew Jeffery### Changed 4553b93d09cSAndrew Jeffery 4563b93d09cSAndrew Jeffery1. pdr: Allow record_handle to be NULL for pldm_pdr_add_check() 4573380a6c6SAndrew Jeffery2. transport: pldm_transport_poll(): Adjust return value semantics 458f56e4dcdSThu Nguyen3. transport: free un-wanted responses in pldm_transport_send_recv_msg() 4593b93d09cSAndrew Jeffery 4608bcbe251SAndrew Jeffery### Deprecated 4618bcbe251SAndrew Jeffery 4628bcbe251SAndrew Jeffery1. state-set: Enum pldm_state_set_operational_fault_status_values 4638bcbe251SAndrew Jeffery 4648bcbe251SAndrew Jeffery The enum operational_fault_status is defined with wrong members and will 4658bcbe251SAndrew Jeffery eventually be replaced with the correct members. Any uses of 4668bcbe251SAndrew Jeffery pldm_state_set_operational_fault_status_values members should move to 4678bcbe251SAndrew Jeffery equivalent pldm_state_set_operational_stress_status_values members if needed. 4688bcbe251SAndrew Jeffery 4698bcbe251SAndrew Jeffery2. platform: Struct field name in fru_record_set PDR 4708bcbe251SAndrew Jeffery 4718bcbe251SAndrew Jeffery References to entity_instance_num should be changed to entity_instance 4728bcbe251SAndrew Jeffery 4738bcbe251SAndrew Jeffery3. platform: Struct field name in numeric sensor value PDR 4748bcbe251SAndrew Jeffery 4758bcbe251SAndrew Jeffery References to entity_instance_num should be changed to entity_instance 4768bcbe251SAndrew Jeffery 4770ecf6bcfSAndrew Jeffery### Removed 4780ecf6bcfSAndrew Jeffery 4790ecf6bcfSAndrew Jeffery1. bios_table: Remove pldm_bios_table_attr_entry_integer_encode_length() 4808b1c0340SAndrew Jeffery2. bios_table: Remove pldm_bios_table_attr_value_entry_encode_enum() 48146d07685SAndrew Jeffery3. bios_table: Remove pldm_bios_table_attr_value_entry_encode_string() 4824e1f131cSAndrew Jeffery4. bios_table: Remove pldm_bios_table_attr_value_entry_encode_integer() 48350dd159eSAndrew Jeffery5. bios_table: Remove pldm_bios_table_append_pad_checksum() 4848810feceSAndrew Jeffery6. fru: Remove get_fru_record_by_option() 485d09b1af0SAndrew Jeffery7. pdr: Make is_present() static 486c79a5df5SAndrew Jeffery8. pdr: Remove pldm_pdr_add() 48714d2984bSAndrew Jeffery9. pdr: Remove pldm_pdr_add_fru_record_set() 4888985dfd1SAndrew Jeffery10. pdr: Remove pldm_entity_association_pdr_add_from_node() 489643c443bSAndrew Jeffery11. pdr: Make find_entity_ref_in_tree() static 49054d91e81SAndrew Jeffery12. pdr: Make entity_association_tree_find() static 4910ecf6bcfSAndrew Jeffery 49243a7985dSThu Nguyen### Fixed 49343a7985dSThu Nguyen 49443a7985dSThu Nguyen1. requester: Fix response buffer cast in pldm_send_recv() 495c6cc028fSAndrew Jeffery2. pdr: Hoist record handle overflow test to avoid memory leak 496ef485068SThu Nguyen3. transport: Correct comparison in while loop condition 49743a7985dSThu Nguyen 4988a4b5336SAndrew Jeffery## [0.4.0] - 2023-07-14 4998a4b5336SAndrew Jeffery 500044ee19aSAndrew Jeffery### Added 501044ee19aSAndrew Jeffery 502044ee19aSAndrew Jeffery1. bios_table: Introduce pldm_bios_table_append_pad_checksum_check() 5037cd16ff8SAndrew Jeffery2. fru: Introduce get_fru_record_by_option_check() 504cc394529SAndrew Jeffery3. pdr: Introduce pldm_entity_association_pdr_add_from_node_check() 505572a3950SAndrew Jeffery4. pdr: Introduce pldm_pdr_add_check() 506c821a700SAndrew Jeffery5. pdr: Introduce pldm_pdr_add_fru_record_set_check() 507044ee19aSAndrew Jeffery 508986df2a1SAndrew Jeffery### Changed 509986df2a1SAndrew Jeffery 510986df2a1SAndrew Jeffery1. requester: Mark pldm_close() as LIBPLDM_ABI_TESTING 5115fb9680bSAndrew Jeffery2. requester: Expose pldm_close() in header 512a873eca0SAndrew Jeffery3. bios_table: pldm_bios_table_string_entry_encode_check(): Handle overflow 513757e81a1SAndrew Jeffery4. bios_table: pldm_bios_table_iter_create(): Return NULL on failed alloc 51473d9176aSAndrew Jeffery5. bios_table: pldm_bios_table_iter_next(): Invalid entry halts iteration 515a8bb22edSAndrew Jeffery6. pdr: pldm_pdr_init(): Return NULL on allocation failure 516fca1b60fSAndrew Jeffery7. pdr: pldm_pdr_destroy(): Exit early if repo is NULL 5175565fcdeSAndrew Jeffery8. pdr: Document preconditions for trivial accessor functions 5185565fcdeSAndrew Jeffery 5195565fcdeSAndrew Jeffery A trivial accessor function is one that exposes properties of an object in a 5205565fcdeSAndrew Jeffery way can't result in an error, beyond passing an invalid argument to the 5215565fcdeSAndrew Jeffery function. For APIs meeting this definition we define a precondition that 5225565fcdeSAndrew Jeffery struct pointers must point to valid objects to avoid polluting the function 5235565fcdeSAndrew Jeffery prototypes. The following APIs now have this precondition explicitly defined: 5245565fcdeSAndrew Jeffery 5255565fcdeSAndrew Jeffery - pldm_entity_extract() 5265565fcdeSAndrew Jeffery - pldm_entity_get_parent() 5275565fcdeSAndrew Jeffery - pldm_entity_is_exist_parent() 5285565fcdeSAndrew Jeffery - pldm_entity_is_node_parent() 5295565fcdeSAndrew Jeffery - pldm_is_current_parent_child 5305565fcdeSAndrew Jeffery - pldm_is_empty_entity_assoc_tree() 5315565fcdeSAndrew Jeffery - pldm_pdr_get_record_count() 5325565fcdeSAndrew Jeffery - pldm_pdr_get_record_handle() 5335565fcdeSAndrew Jeffery - pldm_pdr_get_repo_size() 5345565fcdeSAndrew Jeffery - pldm_pdr_record_is_remote() 535986df2a1SAndrew Jeffery 53615b8818cSAndrew Jeffery9. pdr: pldm_entity_node_get_remote_container_id() is a trivial accessor 53701425e96SAndrew Jeffery10. pdr: pldm_pdr_fru_record_set_find_by_rsi(): Exit early on NULL arguments 538c40037d5SAndrew Jeffery11. pdr: pldm_entity_association_tree_init(): Return NULL on failed alloc 5398e9b0de8SAndrew Jeffery12. pdr: pldm_entity_association_tree_visit(): Document preconditions 540cd17e5ccSAndrew Jeffery13. pdr: pldm_entity_association_tree_visit(): Exit early on failure 541a89e015cSAndrew Jeffery14. pdr: pldm_entity_association_tree_destroy(): Exit early on bad argument 5426e8a2617SAndrew Jeffery15. pdr: pldm_entity_get_num_children(): Return zero for invalid arguments 543375d9fc1SAndrew Jeffery16. pdr: pldm_is_current_parent_child(): Return false for invalid arguments 544c788348eSAndrew Jeffery17. pdr: pldm_entity_association_pdr_add(): Exit early on bad arguments 545ba47e83eSAndrew Jeffery18. pdr: pldm_find_entity_ref_in_tree(): Exit early on bad arguments 54694e364dbSAndrew Jeffery19. pdr: pldm_entity_association_tree_find(): Early exit on bad arguments 54785d7a056SAndrew Jeffery20. pdr: pldm_entity_association_tree_destroy_root(): Exit early on bad arg 5483a5c46b4SAndrew Jeffery21. pdr: pldm_entity_association_pdr_extract(): Early exit on bad arguments 5490dbaa70fSAndrew Jeffery22. pdr: pldm_entity_association_pdr_extract(): Assign out params at exit 550c83ef86dSAndrew Jeffery23. pdr: pldm_entity_get_num_children(): Don't return invalid values 5518526892fSAndrew Jeffery24. libpldm: Lift or remove asserts where a subsequent check exists 55215b8818cSAndrew Jeffery 553fe0f01d8SAndrew Jeffery### Deprecated 554fe0f01d8SAndrew Jeffery 555fe0f01d8SAndrew Jeffery1. pldm_bios_table_attr_entry_integer_encode() 556fe0f01d8SAndrew Jeffery 557fe0f01d8SAndrew Jeffery Migrate to pldm_bios_table_attr_entry_integer_encode_check() 558fe0f01d8SAndrew Jeffery 5597aeb7edbSAndrew Jeffery2. bios_table: Deprecate pldm_bios_table_attr_value_entry_encode_enum() 5607aeb7edbSAndrew Jeffery 5617aeb7edbSAndrew Jeffery Migrate to pldm_bios_table_attr_value_entry_encode_enum_check() 5627aeb7edbSAndrew Jeffery 5632d66393fSAndrew Jeffery3. bios_table: Deprecate pldm_bios_table_attr_value_entry_encode_string() 5642d66393fSAndrew Jeffery 5652d66393fSAndrew Jeffery Migrate to pldm_bios_table_attr_value_entry_encode_string_check() 5662d66393fSAndrew Jeffery 5670088a6aeSAndrew Jeffery4. bios_table: Deprecate pldm_bios_table_attr_value_entry_encode_integer() 5680088a6aeSAndrew Jeffery 5690088a6aeSAndrew Jeffery Migrate to pldm_bios_table_attr_value_entry_encode_integer_check() 5700088a6aeSAndrew Jeffery 571d11bf9f7SAndrew Jeffery5. pdr: Deprecate is_present() 572d11bf9f7SAndrew Jeffery 573d11bf9f7SAndrew Jeffery There should be no users of this symbol. If you are a user, you should figure 574d11bf9f7SAndrew Jeffery out how to stop, or get in touch. This symbol will be marked static the 575d11bf9f7SAndrew Jeffery release after deprecation. 576d11bf9f7SAndrew Jeffery 577bfeb65ebSAndrew Jeffery6. pdr: Deprecate find_entity_ref_in_tree() 578bfeb65ebSAndrew Jeffery 579bfeb65ebSAndrew Jeffery There should be no users of this symbol. If you are a user, you should figure 580bfeb65ebSAndrew Jeffery out how to stop, or get in touch. This symbol will be marked static the 581bfeb65ebSAndrew Jeffery release after deprecation. 582bfeb65ebSAndrew Jeffery 5837f589313SAndrew Jeffery7. pdr: Deprecate entity_association_tree_find() 5847f589313SAndrew Jeffery 5857f589313SAndrew Jeffery There should be no users of this symbol. If you are a user, you should figure 5867f589313SAndrew Jeffery out how to stop, or get in touch. This symbol will be marked static the 5877f589313SAndrew Jeffery release after deprecation. 5887f589313SAndrew Jeffery 5891264fbd9SAndrew Jeffery8. bios_table: Stabilise pldm_bios_table_append_pad_checksum_check() 5901264fbd9SAndrew Jeffery 5911264fbd9SAndrew Jeffery pldm_bios_table_append_pad_checksum() is deprecated by this change. Users of 5921264fbd9SAndrew Jeffery pldm_bios_table_append_pad_checksum() should migrate to 5931264fbd9SAndrew Jeffery pldm_bios_table_append_pad_checksum_check() 5941264fbd9SAndrew Jeffery 595962fcec7SAndrew Jeffery9. fru: Stabilise get_fru_record_by_option_check() 596962fcec7SAndrew Jeffery 597962fcec7SAndrew Jeffery get_fru_record_by_option() is deprecated by this change. Users of 598962fcec7SAndrew Jeffery get_fru_record_by_option() should migrate to get_fru_record_by_option_check() 599962fcec7SAndrew Jeffery 6001354a6eeSAndrew Jeffery10. pdr: Stabilise pldm_entity_association_pdr_add_from_node_check() 6011354a6eeSAndrew Jeffery 6021354a6eeSAndrew Jeffery pldm_entity_association_pdr_add_from_node() is deprecated by this change. 6031354a6eeSAndrew Jeffery Users of pldm_entity_association_pdr_add_from_node() should migrate to 6041354a6eeSAndrew Jeffery pldm_entity_association_pdr_add_from_node_check() 6051354a6eeSAndrew Jeffery 606ca248ce3SAndrew Jeffery11. pdr: Stabilise pldm_pdr_add_check() 607ca248ce3SAndrew Jeffery 608ca248ce3SAndrew Jeffery pldm_pdr_add() is deprecated by this change. Users of pldm_pdr_add() should 609ca248ce3SAndrew Jeffery migrate to pldm_pdr_add_check() 610ca248ce3SAndrew Jeffery 611a2c69117SAndrew Jeffery12. pdr: Stabilise pldm_pdr_add_fru_record_set_check() 612a2c69117SAndrew Jeffery 613a2c69117SAndrew Jeffery pldm_pdr_add_fru_record_set() is deprecated by this change. Users of 614a2c69117SAndrew Jeffery pldm_pdr_add_fru_record_set() should migrate to 615a2c69117SAndrew Jeffery pldm_pdr_add_fru_record_set_check() 616a2c69117SAndrew Jeffery 6176409c8a0SAndrew Jeffery### Removed 6186409c8a0SAndrew Jeffery 6196409c8a0SAndrew Jeffery1. bios_table: Remove deprecated APIs sanitized by assert(): 6206409c8a0SAndrew Jeffery 6216409c8a0SAndrew Jeffery - pldm_bios_table_string_entry_encode() 6226409c8a0SAndrew Jeffery - pldm_bios_table_string_entry_decode_string() 6236409c8a0SAndrew Jeffery - pldm_bios_table_attr_entry_enum_encode() 6246409c8a0SAndrew Jeffery - pldm_bios_table_attr_entry_enum_decode_pv_num() 6256409c8a0SAndrew Jeffery - pldm_bios_table_attr_entry_enum_decode_def_num() 6266409c8a0SAndrew Jeffery - pldm_bios_table_attr_entry_enum_decode_pv_hdls() 6276409c8a0SAndrew Jeffery - pldm_bios_table_attr_entry_string_encode() 6286409c8a0SAndrew Jeffery - pldm_bios_table_attr_entry_string_decode_def_string_length() 6296409c8a0SAndrew Jeffery 63009778a82SAndrew Jeffery### Fixed 631ffd5342cSPavithra Barithaya 632ffd5342cSPavithra Barithaya1. pdr: Return success for pldm_pdr_find_child_container_id_range_exclude() API 6338cf70456SPavithra Barithaya2. pdr: Rework pldm_pdr_find_container_id_range_exclude() API 634a4da6858SAndrew Jeffery3. transport: mctp-demux: Don't test socket for non-zero value 6354e1ba8a7SAndrew Jeffery4. requester: Return PLDM_REQUESTER_OPEN_FAIL from pldm_open() on error 636af7a4d82SAndrew Jeffery5. pdr: pldm_pdr_fru_record_set_find_by_rsi(): Document reality of return 637178531a0SRashmica Gupta6. transport: Fix possible NULL ptr deref in pldm_socket_sndbuf_init() 638cd732d14SAndrew Jeffery7. abi: Update to remove pldm_close() from reference dumps 6399e33be96SAndrew Jeffery8. bios_table: Annotate pldm_bios_table_attr_value_entry_encode_integer() 640ffd5342cSPavithra Barithaya 641291da195SAndrew Jeffery## [0.3.0] - 2023-06-23 642291da195SAndrew Jeffery 6437c250340SDung Cao### Added 6447c250340SDung Cao 6457c250340SDung Cao1. Add encode/decode pldmMessagePollEvent data 64683841fb5SAndrew Jeffery2. README: Add a section on working with libpldm 64739bd2ea5SArchanaKakani3. pdr: Introduce remote_container_id and associated APIs 6489947f9d6SPavithra Barithaya4. pdr: Add APIs for creating and locating remote PDRs 6494d694346SPavithra Barithaya5. pdr: Add pldm_pdr_find_last_in_range() 65025ddbccfSPavithra Barithaya6. pdr: Add pldm_entity_association_pdr_add_from_node_with_record_handle() 6515dc02571SPavithra Barithaya7. pdr: Add pldm_pdr_find_container_id_range_exclude() 6527c250340SDung Cao 653b443b487SRashmica Gupta### Changed 654b443b487SRashmica Gupta 655b443b487SRashmica Gupta1. include: Move installed transport.h under libpldm/ 65683841fb5SAndrew Jeffery2. libpldm: Explicit deprecated, stable and testing ABI classes 6578de8e1ecSAndrew Jeffery3. meson: Reduce strength of oem-ibm requirements from enabled to allowed 6588de8e1ecSAndrew Jeffery 6598de8e1ecSAndrew Jeffery The `oem-ibm` feature is now enabled by the default meson configuration, for 6608de8e1ecSAndrew Jeffery CI purposes. `oem-ibm` is still disabled by default in the `libpldm` bitbake 6618de8e1ecSAndrew Jeffery recipe: 6628de8e1ecSAndrew Jeffery 6630f7218cdSGeorge Liu <https://github.com/openbmc/openbmc/blob/master/meta-phosphor/recipes-phosphor/libpldm/libpldm_git.bb#L10> 6648de8e1ecSAndrew Jeffery 6658de8e1ecSAndrew Jeffery To disable `oem-ibm` in your development builds, pass `-Doem-ibm=disabled` 6668de8e1ecSAndrew Jeffery when invoking `meson setup` 667b443b487SRashmica Gupta 66898c1e69dSAndrew Jeffery4. bios_table: Relax pldm_bios_table_string_entry_decode_string_check() 6690c9f5a8aSAndrew Jeffery5. bios_table: Relax pldm_bios_table_attr_entry_enum_decode_pv_hdls_check() 67098c1e69dSAndrew Jeffery 671d47e8ab8SAndrew Jeffery### Deprecated 672d47e8ab8SAndrew Jeffery 673d47e8ab8SAndrew Jeffery1. bios_table: Deprecate APIs with arguments sanitized using assert() 674d47e8ab8SAndrew Jeffery 675d47e8ab8SAndrew Jeffery C provides enough foot-guns without us encoding them into library APIs. 676d47e8ab8SAndrew Jeffery Specifically, deprecate the following in favour of their `*_check()` variants 677d47e8ab8SAndrew Jeffery which ensure assertions won't fail or otherwise invoke UB: 678d47e8ab8SAndrew Jeffery 679d47e8ab8SAndrew Jeffery - pldm_bios_table_string_entry_encode() 680d47e8ab8SAndrew Jeffery - pldm_bios_table_string_entry_decode_string() 681d47e8ab8SAndrew Jeffery - pldm_bios_table_attr_entry_enum_encode() 682d47e8ab8SAndrew Jeffery - pldm_bios_table_attr_entry_enum_decode_pv_num() 683d47e8ab8SAndrew Jeffery - pldm_bios_table_attr_entry_enum_decode_def_num() 684d47e8ab8SAndrew Jeffery - pldm_bios_table_attr_entry_enum_decode_pv_hdls() 685d47e8ab8SAndrew Jeffery - pldm_bios_table_attr_entry_string_encode() 686d47e8ab8SAndrew Jeffery - pldm_bios_table_attr_entry_string_decode_def_string_length() 687d47e8ab8SAndrew Jeffery 6884b4603b3SAndrew Jeffery### Removed 6894b4603b3SAndrew Jeffery 6904b4603b3SAndrew Jeffery1. libpldm: Remove the requester-api option 6914b4603b3SAndrew Jeffery 69239f88325SRashmica Gupta### Fixed 69339f88325SRashmica Gupta 69439f88325SRashmica Gupta1. requester: Make pldm_open() return existing fd 695abaf61f4SDung Cao2. transport: Prevent sticking in waiting for response 696b01fb1ccSThu Nguyen3. transport: Match on response in pldm_transport_send_recv_msg() 697a3035938SRashmica Gupta4. requester: Add check before accessing hdr in pldm_recv() 698df02e360SAndrew Jeffery5. bios_table: pldm_bios_table_attr_entry_string_info_check() NULL deref 699