dso_start = get_optional(param_dict, "dso_map_start")
        dso_end = get_optional(param_dict, "dso_map_end")
        symbol = get_optional(param_dict, "symbol")
+       map_pgoff = get_optional(param_dict, "map_pgoff")
+       # check for valid map offset
+       if (str(map_pgoff) == '[unknown]'):
+               map_pgoff = 0
 
        cpu = sample["cpu"]
        ip = sample["ip"]
        # Record for previous sample packet
        cpu_data[str(cpu) + 'addr'] = addr
 
-       # Handle CS_ETM_TRACE_ON packet if start_addr=0 and stop_addr=4
-       if (start_addr == 0 and stop_addr == 4):
-               print("CPU%d: CS_ETM_TRACE_ON packet is inserted" % cpu)
+       # Filter out zero start_address. Optionally identify CS_ETM_TRACE_ON packet
+       if (start_addr == 0):
+               if ((stop_addr == 4) and (options.verbose == True)):
+                       print("CPU%d: CS_ETM_TRACE_ON packet is inserted" % cpu)
                return
 
        if (start_addr < int(dso_start) or start_addr > int(dso_end)):
                # vm_start to zero.
                if (dso == "[kernel.kallsyms]" or dso_start == 0x400000):
                        dso_vm_start = 0
+                       map_pgoff = 0
                else:
                        dso_vm_start = int(dso_start)
 
                dso_fname = get_dso_file_path(dso, dso_bid)
                if path.exists(dso_fname):
-                       print_disam(dso_fname, dso_vm_start, start_addr, stop_addr)
+                       print_disam(dso_fname, dso_vm_start, start_addr + map_pgoff, stop_addr + map_pgoff)
                else:
-                       print("Failed to find dso %s for address range [ 0x%x .. 0x%x ]" % (dso, start_addr, stop_addr))
+                       print("Failed to find dso %s for address range [ 0x%x .. 0x%x ]" % (dso, start_addr + map_pgoff, stop_addr + map_pgoff))
 
        print_srccode(comm, param_dict, sample, symbol, dso)