Class MemorySectionResolver


  • public abstract class MemorySectionResolver
    extends java.lang.Object
    • Field Summary

      Fields 
      ChangeModifier and Type Field Description
      NEWprotected Program program  
    • Method Summary

      All Methods Instance Methods Abstract Methods Concrete Methods 
      ChangeModifier and Type Method Description
      void addInitializedMemorySection​(MemoryLoadable key, long fileOffset, long numberOfBytes, Address startAddress, java.lang.String sectionName, boolean isReadable, boolean isWritable, boolean isExecutable, java.lang.String comment, boolean isFragmentationOK, boolean isLoadedSection)
      Add initialized memory "section" based upon a specified data source fileOffset.
      void addUninitializedMemorySection​(MemoryLoadable key, long numberOfBytes, Address startAddress, java.lang.String sectionName, boolean isReadable, boolean isWritable, boolean isExecutable, java.lang.String comment, boolean isFragmentationOK)
      Add uninitialized memory "section".
      NEWprotected abstract MemoryBlock createInitializedBlock​(MemoryLoadable key, boolean isOverlay, java.lang.String name, Address start, long fileOffset, long length, java.lang.String comment, boolean r, boolean w, boolean x, TaskMonitor monitor)
      Create a memory block (possible fragment if conflicts resolved) for the specified loadable "section".
      NEWprotected abstract MemoryBlock createUninitializedBlock​(MemoryLoadable key, boolean isOverlay, java.lang.String name, Address start, long length, java.lang.String comment, boolean r, boolean w, boolean x)
      Create a memory block (possible fragment if conflicts resolved) for the specified loadable "section".
      Memory getMemory()
      Get program memory object
      Program getProgram()
      Get program object
      void resolve​(TaskMonitor monitor)
      Perform final resolve of all defined memory "sections" to establish final memory mappings.
      • Methods inherited from class java.lang.Object

        clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Field Detail

      • program NEW

        protected final Program program

Constructor Detail

  • Method Detail

    • addInitializedMemorySection

      public void addInitializedMemorySection​(MemoryLoadable key,
                                              long fileOffset,
                                              long numberOfBytes,
                                              Address startAddress,
                                              java.lang.String sectionName,
                                              boolean isReadable,
                                              boolean isWritable,
                                              boolean isExecutable,
                                              java.lang.String comment,
                                              boolean isFragmentationOK,
                                              boolean isLoadedSection)
                                       throws AddressOverflowException
      Add initialized memory "section" based upon a specified data source fileOffset. The last "section" defined will take precedence when resolving conflicts. Sections identified as loaded will take precedence over those that are non-loaded. placed into memory
      Parameters:
      key - the loadable section key which corresponds to this memory "section"
      fileOffset - data source file offset. It is assumed that all initialized "sections" draw from a single data source.
      length - number of bytes within "section"
      startAddress - desired physical start address of "section"
      sectionName - name of "section"
      isReadable - true if "section" has read privilege
      isWritable - true if "section" has write privilege
      isExecutable - true if "section" has execute privilege
      comment - section comment (used as basis for block comment)
      isFragmentationOK - if true this memory section may be fragmented due to
      isLoadedSection - if true this memory section will take precedence over non-loaded sections conflict/overlap with other memory sections of higher precedence.
      Throws:
      AddressOverflowException
    • addUninitializedMemorySection

      public void addUninitializedMemorySection​(MemoryLoadable key,
                                                long numberOfBytes,
                                                Address startAddress,
                                                java.lang.String sectionName,
                                                boolean isReadable,
                                                boolean isWritable,
                                                boolean isExecutable,
                                                java.lang.String comment,
                                                boolean isFragmentationOK)
                                         throws AddressOverflowException
      Add uninitialized memory "section". The last "section" defined will take precedence when resolving conflicts.
      Parameters:
      key - the loadable section key which corresponds to this memory "section"
      length - number of bytes within "section"
      startAddress - desired physical start address of "section"
      sectionName - name of "section"
      isReadable - true if "section" has read privilege
      isWritable - true if "section" has write privilege
      isExecutable - true if "section" has execute privilege
      comment - section comment (used as basis for block comment)
      isFragmentationOK - if true this memory section may be fragmented due to conflict/overlap with other memory sections of higher precedence.
      Throws:
      AddressOverflowException
    • resolve

      public void resolve​(TaskMonitor monitor)
                   throws CancelledException
      Perform final resolve of all defined memory "sections" to establish final memory mappings. This method will resolve all conflicts and create memory blocks within the associated program.
      Parameters:
      monitor -
      Throws:
      CancelledException
    • getMemory

      public Memory getMemory()
      Get program memory object
      Returns:
      program memory
    • getProgram

      public Program getProgram()
      Get program object
      Returns:
      program
    • createInitializedBlock NEW

      protected abstract MemoryBlock createInitializedBlock​(MemoryLoadable key,
                                                            boolean isOverlay,
                                                            java.lang.String name,
                                                            Address start,
                                                            long fileOffset,
                                                            long length,
                                                            java.lang.String comment,
                                                            boolean r,
                                                            boolean w,
                                                            boolean x,
                                                            TaskMonitor monitor)
                                                     throws java.io.IOException,
                                                            AddressOverflowException,
                                                            CancelledException
      Create a memory block (possible fragment if conflicts resolved) for the specified loadable "section". If multiple blocks are created due to size restrictions only the first block will be returned. The returned block's length can be checked to determine if this has occurred.
      Parameters:
      key - the loadable section key which corresponds to this memory block or null for an adhoc block
      isOverlay - true if an overlay should be created
      name - unique name assignment based upon original "section" name
      start - starting physical address of block
      fileOffset - starting file offset for initialized data source
      length - number of bytes in block
      comment - block comment
      r - true if "section" has read privilege
      w - true if "section" has write privilege
      x - true if "section" has execute privilege
      Returns:
      memory block
      Throws:
      java.io.IOException
      AddressOverflowException
      CancelledException
    • createUninitializedBlock NEW

      protected abstract MemoryBlock createUninitializedBlock​(MemoryLoadable key,
                                                              boolean isOverlay,
                                                              java.lang.String name,
                                                              Address start,
                                                              long length,
                                                              java.lang.String comment,
                                                              boolean r,
                                                              boolean w,
                                                              boolean x)
                                                       throws java.io.IOException,
                                                              AddressOverflowException,
                                                              CancelledException
      Create a memory block (possible fragment if conflicts resolved) for the specified loadable "section". If multiple blocks are created due to size restrictions only the first block will be returned. The returned block's length can be checked to determine if this has occurred.
      Parameters:
      key - the loadable section key which corresponds to this memory block or null for an adhoc block
      isOverlay - true if an overlay should be created
      name - unique name assignment based upon original "section" name
      start - starting physical address of block
      length - number of bytes in block
      comment - block comment
      r - true if "section" has read privilege
      w - true if "section" has write privilege
      x - true if "section" has execute privilege
      Returns:
      memory block
      Throws:
      java.io.IOException
      AddressOverflowException
      CancelledException