From dcc689d9c4800032b2fe6c4b092c55d5d7472fba Mon Sep 17 00:00:00 2001 From: Harald Welte Date: Sun, 24 Jul 2022 12:22:17 +0200 Subject: [PATCH] apdu/ts_102_221: SELECT: allow select of parent/ancestor DFs We need to pass the 'PARENT' flag to get_selectables() to be able to track SELECT on any of the parent/ancestor DF FID. Change-Id: Ia7ac627d5edccb97160c90688d720d887fad6ec7 --- pySim/apdu/ts_102_221.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pySim/apdu/ts_102_221.py b/pySim/apdu/ts_102_221.py index 3597db85..769c38e9 100644 --- a/pySim/apdu/ts_102_221.py +++ b/pySim/apdu/ts_102_221.py @@ -66,7 +66,7 @@ class UiccSelect(ApduCommand, n='SELECT', ins=0xA4, cla=['0X', '4X', '6X']): # iterate to next element in path continue else: - sels = lchan.selected_file.get_selectables(['FIDS','MF']) + sels = lchan.selected_file.get_selectables(['FIDS','MF','PARENT']) if file_hex in sels: if self.successful: #print("\tSELECT %s" % sels[file_hex]) @@ -80,7 +80,7 @@ class UiccSelect(ApduCommand, n='SELECT', ins=0xA4, cla=['0X', '4X', '6X']): elif mode == 'df_ef_or_mf_by_file_id': if len(self.cmd_data) != 2: raise ValueError('Expecting a 2-byte FID') - sels = lchan.selected_file.get_selectables(['FIDS','MF']) + sels = lchan.selected_file.get_selectables(['FIDS','MF','PARENT']) file_hex = b2h(self.cmd_data) if file_hex in sels: if self.successful: