Claims
- 1. A data system comprising:
(i) a multiplicity of data processors; (ii) a data memory; (iii) a bus system coupling the data processors to said data memory, said bus system supporting memory transactions from said data processors to said data memory, said memory transactions each including memory address data relating to said data memory and an identification of a respective data processor in said multiplicity thereof; (iv) at least one arbitration stage for arbitrating between memory transactions intended for said data memory; and (v) protective means coupled to said bus system, between said one arbitration stage and said memory, said protective means comprising:
(a) storage means for storing limits defining regions of said memory allotted to respective ones of the data processors; and (b) means responsive to a memory transaction and said storage means to determine whether said memory transaction is allowed to proceed to said data memory.
- 2. A data system according to claim 1 wherein said means responsive to a memory transaction includes:
means for extracting memory address data and a source identification from the memory transaction; means responsive to said source identification to access said storage means; and means for comparing limits provided by said storage means with said memory address data extracted from the memory transaction.
- 3. A data system according to claim 1 wherein said means responsive to a memory transaction comprises a state machine.
- 4. A data system according to claim 1 and further comprising a storage buffer for temporarily storing a memory transaction which is allowed to proceed to said data memory.
- 5. A data system according to claim 1 and further comprising means for storing indications of selected fields in said memory transactions and responsive to memory transactions to detect change in any of said fields and thereupon to generate an interrupt for a respective data processor.
- 6. A data system comprising:
(i) a multiplicity of data handling cores; (ii) a data memory; (iii) a bus system coupling the cores to said data memory, said bus system supporting memory transactions from said cores to said data memory, said memory transactions each including memory address data relating to said data memory and a source identification of a respective core in said multiplicity thereof; and (iv) protective means coupled to said bus system and said memory, said protective means comprising:
(a) registers for storing source identifications and limits defining regions of said memory allotted to respective ones of the cores; and (b) logic means responsive to a memory transaction and said storage means to determine whether said memory transaction is allowed to proceed to said data memory.
- 7. A data system according to claim 6 wherein said logic means includes:
means for extracting memory address data and a source identification from the memory transaction; means responsive to said source identification to access said registers storing said limits in accordance with a match between the source identification extracted from the memory transaction and a source identification stored in the registers; and means for comparing limits provided by said registers with said address data from the memory transaction.
- 8. A data system according to claim 6 wherein said logic includes a state machine.
- 9. A data system according to claim 6 and further comprising a storage buffer for temporarily storing a memory transaction which is allowed to proceed to said data memory.
- 10. A data system according to claim 6 and further comprising means for storing indications of respective fields and responsive to memory transactions to detect change in any of said fields and thereupon to generate an interrupt.
- 11. A data system on a chip comprising:
(i) a multiplicity of data processors; (ii) a memory interface; (iii) a bus system coupling the data processors to said memory interface, said bus system supporting memory transactions from said data processors to said memory interface, said memory transactions each including memory address data and an identification of a respective data processor in said multiplicity thereof; (iv) at least one arbitration stage for arbitrating between memory transactions intended for said memory interface; (v) protective means coupled to said bus system, between said one arbitration stage and said memory interface, said protective means comprising:
(a) storage means for storing limits defining regions of said memory allotted to respective ones of the data processors; (b) means for extracting memory address data and a source identification from the memory transaction; (c) means responsive to said source identification to access said storage means; and (d) means for comparing limits provided by said storage means with said memory address data extracted from the memory transaction; and (e) a storage buffer for temporarily storing a memory transaction which is allowed to proceed to said memory interface.
- 12. A data system on a chip comprising:
(i) a multiplicity of data handling cores including data processors; (ii) a memory interface; (iii) a bus system coupling the cores to said memory interface, said bus system supporting memory transactions from said data processors to said memory interface, said memory transactions each including memory address data and a source identification of a respective core in said multiplicity thereof; and (iv) protective means coupled to said bus system and said memory interface, said protective means comprising:
(a) registers for storing source identifications and limits defining regions of said memory allotted to respective ones of the cores; and (b) logic means responsive to a memory transaction and said storage means to determine whether said memory transaction is allowed to proceed to said memory interface, said logic means including:
means for extracting memory address data and a source identification from the memory transaction; means responsive to said source identification to access said registers storing said limits in accordance with a match between the source identification extracted from the memory transaction and a source identification stored in the registers; and means for comparing limits provided by said registers with said address data from the memory transaction.
- 13. A data system on a chip according to claim 12 wherein said logic means includes a state machine.
- 14. A data system on a chip according to claim 12 and further comprising a storage buffer for temporarily storing a memory transaction which is allowed to proceed to said memory interface.
- 15. A data system on a chip according to claim 12 and further comprising means for storing indications of selected fields in said memory transactions and responsive to memory transactions to detect change in any of said fields and thereupon to generate an interrupt.
Priority Claims (1)
Number |
Date |
Country |
Kind |
0121402.2 |
Sep 2001 |
GB |
|
REFERENCE TO RELATED APPLICATIONS
[0001] Pratt et al., Ser. No. 09/879,065 filed Jun. 13, 2001, commonly assigned herewith and incorporated by reference herein.
[0002] Creedon et al., Ser. No. 09/893,659 filed Jun. 29, 2001, commonly assigned herewith and incorporated by reference herein.
[0003] Hughes et al., Ser. No. 09/893,658 filed June 29, 2001, commonly assigned herewith and incorporated by reference herein.
[0004] Boylan et al., Ser. No. not yet allotted, entitled ‘AUTOMATIC GENERATION OF INTERCONNECT LOGIC COMPONENTS’, filed Aug. 2, 2001, commonly assigned herewith and incorporated by reference herein.