Hi Tung Lun,

Should we update ConfigEditorUserManual.md for this new function?

Thanks,
Chasel


> -----Original Message-----
> From: Loo, Tung Lun <tung.lun....@intel.com>
> Sent: Friday, October 15, 2021 8:39 AM
> To: devel@edk2.groups.io
> Cc: Loo, Tung Lun <tung.lun....@intel.com>; Ma, Maurice
> <maurice...@intel.com>; Desimone, Nathaniel L
> <nathaniel.l.desim...@intel.com>; Zeng, Star <star.z...@intel.com>; Chiu,
> Chasel <chasel.c...@intel.com>
> Subject: [PATCH] IntelFsp2Pkg: Add support for config editor to handle 
> multiple
> UPD
> 
> BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=3692
> 
> In several use cases in bootloader, there are multiple instances of UPD with
> same signature header. As such, using previous version of config editor to 
> edit
> those will result in only overriding the first found instance. This patch 
> provides
> the flexibility to modify the instance specified.
> 
> Cc: Maurice Ma <maurice...@intel.com>
> Cc: Nate DeSimone <nathaniel.l.desim...@intel.com>
> Cc: Star Zeng <star.z...@intel.com>
> Cc: Chasel Chiu <chasel.c...@intel.com>
> 
> Signed-off-by: Loo Tung Lun <tung.lun....@intel.com>
> ---
>  IntelFsp2Pkg/Tools/ConfigEditor/GenYamlCfg.py | 94
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-----
> ---------------------------
>  1 file changed, 62 insertions(+), 32 deletions(-)
> 
> diff --git a/IntelFsp2Pkg/Tools/ConfigEditor/GenYamlCfg.py
> b/IntelFsp2Pkg/Tools/ConfigEditor/GenYamlCfg.py
> index b593885807..91c4180085 100644
> --- a/IntelFsp2Pkg/Tools/ConfigEditor/GenYamlCfg.py
> +++ b/IntelFsp2Pkg/Tools/ConfigEditor/GenYamlCfg.py
> @@ -1351,24 +1351,20 @@ option format '%s' !" % option)
>                                  act_cfg['value']                         
> option = act_cfg['option'] -
> cfg_val = ''-                        bin_val = ''                         for 
> i in option.split(','):
> if act_cfg['value'] in i:-                                bin_val = i+
> self.data_diff += \+                                    '\n\nBinary:          
> ' \+                                    +
> act_cfg['name'] + ': ' \+                                    + i + '\n'       
>                       elif
> config_val in i:-                                cfg_val = i-                 
>        if cfg_val != '' and
> bin_val != '':-                            self.data_diff += '\n\nBinary:     
>    ' \-
> + act_cfg['name'] \-                                + ': ' + 
> bin_val.replace(' ', '') \-
> + '\nConfig file:   ' \-                                + act_cfg['name'] + 
> ': ' \-
> + cfg_val.replace(' ', '') + '\n'+                                
> self.data_diff += \+
> '\nConfig file:     ' \+                                    + act_cfg['name'] 
> + ': ' + i
> else:-                        self.data_diff += '\n\nBinary:        ' \+
> self.data_diff += '\n\nBinary:           ' \                             + 
> act_cfg['name'] + ': ' +
> act_cfg['value'] \-                            + '\nConfig file:   ' + 
> act_cfg['name'] \+
> + '\nConfig file:     ' + act_cfg['name'] \                             + ': 
> ' + config_val + '\n'
> def set_field_value(self, top, value_bytes, force=False):@@ -1477,33 +1473,67
> @@ for '%s' !" % (act_cfg['value'], act_cfg['path']))
>      def get_bin_segment(self, bin_data):         cfg_segs = 
> self.get_cfg_segment()
> bin_segs = []+        fsp_instance = []         for seg in cfg_segs:          
>    key =
> seg[0].encode()+            print("key ", key)             if key == 0:
> bin_segs.append([seg[0], 0, len(bin_data)])                 break             
> pos =
> bin_data.find(key)-            if pos >= 0:-                # ensure no other 
> match for the
> key-                next_pos = bin_data.find(key, pos + len(seg[0]))-         
>        if
> next_pos >= 0:-                    if key == b'$SKLFSP$' or key == 
> b'$BSWFSP$':-
> string = ('Warning: Multiple matches for %s in '-                             
>      'binary!\n\nA
> workaround applied to such '-                                  'FSP 1.x 
> binary to use second'-
> ' match instead of first match!' % key)-
> messagebox.showwarning('Warning!', string)-                        pos = 
> next_pos-
> else:-                        print("Warning: Multiple matches for '%s' "-
> "in binary, the 1st instance will be used !"-                              % 
> seg[0])-
> bin_segs.append([seg[0], pos, seg[2]])-                
> self.binseg_dict[seg[0]] = pos-
> else:+            while pos != -1:+                fsp_instance.append(pos)+  
>               pos =
> bin_data.find(key, pos + len(seg[0]))+            if len(fsp_instance) <= 0:
> bin_segs.append([seg[0], -1, seg[2]])                 
> self.binseg_dict[seg[0]] = -1-
> continue++            elif len(fsp_instance) == 1:+                
> bin_segs.append([seg[0],
> fsp_instance[0], seg[2]])+                self.binseg_dict[seg[0]] = 
> fsp_instance[0]+
> fsp_instance.clear()++            else:++                fsp_instance_root = 
> tkinter.Tk()++
> canvas1 = tkinter.Canvas(fsp_instance_root,+                                  
>        width=400,
> height=400)+                canvas1.pack()++                entry1 =
> tkinter.Entry(fsp_instance_root)+                canvas1.create_window(200, 
> 220,
> window=entry1)++                text = "Multiple instances available for " +\+
> seg[0] + "\n\nThe available instances are\n"+                for edx, ins in
> enumerate(fsp_instance):+                    text += "\nInstance" + str(edx + 
> 1) +
> ' :offset  ' +\+                         str(hex(ins))+                text 
> += "\n\nPlease enter the
> instance number between 1 and "\+                    + str(len(fsp_instance))+
> label1 = tkinter.Label(+                    fsp_instance_root,+               
>      text=text,
> wraplength=380, justify='left')+                canvas1.create_window(200, 90,
> window=label1)++                def getfspinstance():+                    x1 
> = entry1.get()+
> fsp_instance_option = int(x1)+                    if fsp_instance_option <=
> len(fsp_instance):+                        bin_segs.append([seg[0],+
> fsp_instance[fsp_instance_option - 1],+                                       
>  seg[2]])+
> self.binseg_dict[seg[0]] = fsp_instance[+                            
> fsp_instance_option -
> 1]+                    fsp_instance_root.destroy()++                button2 =
> tkinter.Button(fsp_instance_root,+                                         
> text='Enter the
> instance',+                                         command=lambda: 
> getfspinstance())+
> canvas1.create_window(200, 250, window=button2)+
> fsp_instance_root.wait_window(fsp_instance_root)++
> fsp_instance.clear()          return bin_segs --
> 2.26.2.windows.1



-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#82208): https://edk2.groups.io/g/devel/message/82208
Mute This Topic: https://groups.io/mt/86328919/21656
Group Owner: devel+ow...@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [arch...@mail-archive.com]
-=-=-=-=-=-=-=-=-=-=-=-


Reply via email to