Where does the Z80 processor start executing from?How did the Z80 instruction set differ from the 8080?Why...

Overloading istream>> to read comma-separated input

Short story about space worker geeks who zone out by 'listening' to radiation from stars

Why are there no referendums in the US?

How did Arya survive the stabbing?

Sort a list by elements of another list

How to safely derail a train during transit?

Is `x >> pure y` equivalent to `liftM (const y) x`

What is the difference between "behavior" and "behaviour"?

Nautlius: add mouse right-click action to compute MD5 sum

Avoiding estate tax by giving multiple gifts

Hostile work environment after whistle-blowing on coworker and our boss. What do I do?

Opposite of a diet

Why didn't Theresa May consult with Parliament before negotiating a deal with the EU?

Why is Lord Kartikeya called 'Devasenapati'?

What does "I’d sit this one out, Cap," imply or mean in the context?

How do I go from 300 unfinished/half written blog posts, to published posts?

Trouble understanding the speech of overseas colleagues

Where does the Z80 processor start executing from?

How to escape string to filename? It is in backup a file append date

How does the UK government determine the size of a mandate?

How to Reset Passwords on Multiple Websites Easily?

Is this apparent Class Action settlement a spam message?

How many times can American Tourist re-enter UK in same 6 month period?

What is the best translation for "slot" in the context of multiplayer video games?



Where does the Z80 processor start executing from?


How did the Z80 instruction set differ from the 8080?Why does the Z80 have a half-carry bit?How fast is memcpy on the Z80?z80 crashes after executing some instructionsWhy does the Z80 include the RLD and RRD instructions?Why is the Z80's supply pin in the middle of the data pins?Why did TI-8x calculator series use the Z80 processor?Role of the Z80 co-processor in GBA gamesHow do I Interface a PS/2 Keyboard without Modern Techniques?What does ld a,(hl) do in this piece of Z80 ASM code, and why is HL incremented?













4















Strangely I can't find this information anywhere online -- I've thoroughly looked at the datasheet, and I've searched things like "Z80 program counter initial value" -- but I can't find anything!



My question is simply: when the Z80 just turns on, what value does the program counter take? (i.e., what instruction does it start executing from?)



Logically, I'd assume it initialises to 0, but I want to be sure of this.










share|improve this question







New contributor




Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.

























    4















    Strangely I can't find this information anywhere online -- I've thoroughly looked at the datasheet, and I've searched things like "Z80 program counter initial value" -- but I can't find anything!



    My question is simply: when the Z80 just turns on, what value does the program counter take? (i.e., what instruction does it start executing from?)



    Logically, I'd assume it initialises to 0, but I want to be sure of this.










    share|improve this question







    New contributor




    Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.























      4












      4








      4








      Strangely I can't find this information anywhere online -- I've thoroughly looked at the datasheet, and I've searched things like "Z80 program counter initial value" -- but I can't find anything!



      My question is simply: when the Z80 just turns on, what value does the program counter take? (i.e., what instruction does it start executing from?)



      Logically, I'd assume it initialises to 0, but I want to be sure of this.










      share|improve this question







      New contributor




      Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.












      Strangely I can't find this information anywhere online -- I've thoroughly looked at the datasheet, and I've searched things like "Z80 program counter initial value" -- but I can't find anything!



      My question is simply: when the Z80 just turns on, what value does the program counter take? (i.e., what instruction does it start executing from?)



      Logically, I'd assume it initialises to 0, but I want to be sure of this.







      z80






      share|improve this question







      New contributor




      Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question







      New contributor




      Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question






      New contributor




      Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 3 hours ago









      Jacob GarbyJacob Garby

      1233




      1233




      New contributor




      Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      Jacob Garby is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






















          1 Answer
          1






          active

          oldest

          votes


















          6














          Yes, it's zero - like the 8080 it descends from.



          Excerpt from Zilog's March 1978 Product Specification (datasheet), page 2, Pin Description, here the /RESET signal (emphasis mine):




          Input, active low. RESET initializes the CPU as follows:
          reset interrupt enable flip-flop, clear PC and registers
          I and R and set interrupt to 8080A mode.




          Similar the description in the 1977 Z80 Technical Manual (03-0029-01) on page 9.






          share|improve this answer


























          • Thanks! I actually didn't know that the 8080 started at zero either, but it makes complete sense.

            – Jacob Garby
            3 hours ago











          • (I'll accept the answer as soon as I can)

            – Jacob Garby
            3 hours ago











          • Does anything not start at zero?

            – dashnick
            1 hour ago






          • 4





            @dashnick Many don't just start, but take a vector form a predefined location like 6500 and 6800 start at the vector residing at FFFE/FF, 68k takes the initial PC from Vector 1 (address 4..7). Other do start form some address where the IOC locates a loader record, and so on. Starting from Zero is only one of many ways.

            – Raffzahn
            47 mins ago






          • 3





            Intels 8086 employs an interesting combination by starting a offset zero, like 8080/Z80, but in segment FFFF, thus at absolute address FFFF0.

            – Raffzahn
            26 mins ago











          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "648"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          noCode: true, onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });






          Jacob Garby is a new contributor. Be nice, and check out our Code of Conduct.










          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fretrocomputing.stackexchange.com%2fquestions%2f9448%2fwhere-does-the-z80-processor-start-executing-from%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          6














          Yes, it's zero - like the 8080 it descends from.



          Excerpt from Zilog's March 1978 Product Specification (datasheet), page 2, Pin Description, here the /RESET signal (emphasis mine):




          Input, active low. RESET initializes the CPU as follows:
          reset interrupt enable flip-flop, clear PC and registers
          I and R and set interrupt to 8080A mode.




          Similar the description in the 1977 Z80 Technical Manual (03-0029-01) on page 9.






          share|improve this answer


























          • Thanks! I actually didn't know that the 8080 started at zero either, but it makes complete sense.

            – Jacob Garby
            3 hours ago











          • (I'll accept the answer as soon as I can)

            – Jacob Garby
            3 hours ago











          • Does anything not start at zero?

            – dashnick
            1 hour ago






          • 4





            @dashnick Many don't just start, but take a vector form a predefined location like 6500 and 6800 start at the vector residing at FFFE/FF, 68k takes the initial PC from Vector 1 (address 4..7). Other do start form some address where the IOC locates a loader record, and so on. Starting from Zero is only one of many ways.

            – Raffzahn
            47 mins ago






          • 3





            Intels 8086 employs an interesting combination by starting a offset zero, like 8080/Z80, but in segment FFFF, thus at absolute address FFFF0.

            – Raffzahn
            26 mins ago
















          6














          Yes, it's zero - like the 8080 it descends from.



          Excerpt from Zilog's March 1978 Product Specification (datasheet), page 2, Pin Description, here the /RESET signal (emphasis mine):




          Input, active low. RESET initializes the CPU as follows:
          reset interrupt enable flip-flop, clear PC and registers
          I and R and set interrupt to 8080A mode.




          Similar the description in the 1977 Z80 Technical Manual (03-0029-01) on page 9.






          share|improve this answer


























          • Thanks! I actually didn't know that the 8080 started at zero either, but it makes complete sense.

            – Jacob Garby
            3 hours ago











          • (I'll accept the answer as soon as I can)

            – Jacob Garby
            3 hours ago











          • Does anything not start at zero?

            – dashnick
            1 hour ago






          • 4





            @dashnick Many don't just start, but take a vector form a predefined location like 6500 and 6800 start at the vector residing at FFFE/FF, 68k takes the initial PC from Vector 1 (address 4..7). Other do start form some address where the IOC locates a loader record, and so on. Starting from Zero is only one of many ways.

            – Raffzahn
            47 mins ago






          • 3





            Intels 8086 employs an interesting combination by starting a offset zero, like 8080/Z80, but in segment FFFF, thus at absolute address FFFF0.

            – Raffzahn
            26 mins ago














          6












          6








          6







          Yes, it's zero - like the 8080 it descends from.



          Excerpt from Zilog's March 1978 Product Specification (datasheet), page 2, Pin Description, here the /RESET signal (emphasis mine):




          Input, active low. RESET initializes the CPU as follows:
          reset interrupt enable flip-flop, clear PC and registers
          I and R and set interrupt to 8080A mode.




          Similar the description in the 1977 Z80 Technical Manual (03-0029-01) on page 9.






          share|improve this answer















          Yes, it's zero - like the 8080 it descends from.



          Excerpt from Zilog's March 1978 Product Specification (datasheet), page 2, Pin Description, here the /RESET signal (emphasis mine):




          Input, active low. RESET initializes the CPU as follows:
          reset interrupt enable flip-flop, clear PC and registers
          I and R and set interrupt to 8080A mode.




          Similar the description in the 1977 Z80 Technical Manual (03-0029-01) on page 9.







          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited 3 hours ago









          George Phillips

          3,5211522




          3,5211522










          answered 3 hours ago









          RaffzahnRaffzahn

          54k6132218




          54k6132218













          • Thanks! I actually didn't know that the 8080 started at zero either, but it makes complete sense.

            – Jacob Garby
            3 hours ago











          • (I'll accept the answer as soon as I can)

            – Jacob Garby
            3 hours ago











          • Does anything not start at zero?

            – dashnick
            1 hour ago






          • 4





            @dashnick Many don't just start, but take a vector form a predefined location like 6500 and 6800 start at the vector residing at FFFE/FF, 68k takes the initial PC from Vector 1 (address 4..7). Other do start form some address where the IOC locates a loader record, and so on. Starting from Zero is only one of many ways.

            – Raffzahn
            47 mins ago






          • 3





            Intels 8086 employs an interesting combination by starting a offset zero, like 8080/Z80, but in segment FFFF, thus at absolute address FFFF0.

            – Raffzahn
            26 mins ago



















          • Thanks! I actually didn't know that the 8080 started at zero either, but it makes complete sense.

            – Jacob Garby
            3 hours ago











          • (I'll accept the answer as soon as I can)

            – Jacob Garby
            3 hours ago











          • Does anything not start at zero?

            – dashnick
            1 hour ago






          • 4





            @dashnick Many don't just start, but take a vector form a predefined location like 6500 and 6800 start at the vector residing at FFFE/FF, 68k takes the initial PC from Vector 1 (address 4..7). Other do start form some address where the IOC locates a loader record, and so on. Starting from Zero is only one of many ways.

            – Raffzahn
            47 mins ago






          • 3





            Intels 8086 employs an interesting combination by starting a offset zero, like 8080/Z80, but in segment FFFF, thus at absolute address FFFF0.

            – Raffzahn
            26 mins ago

















          Thanks! I actually didn't know that the 8080 started at zero either, but it makes complete sense.

          – Jacob Garby
          3 hours ago





          Thanks! I actually didn't know that the 8080 started at zero either, but it makes complete sense.

          – Jacob Garby
          3 hours ago













          (I'll accept the answer as soon as I can)

          – Jacob Garby
          3 hours ago





          (I'll accept the answer as soon as I can)

          – Jacob Garby
          3 hours ago













          Does anything not start at zero?

          – dashnick
          1 hour ago





          Does anything not start at zero?

          – dashnick
          1 hour ago




          4




          4





          @dashnick Many don't just start, but take a vector form a predefined location like 6500 and 6800 start at the vector residing at FFFE/FF, 68k takes the initial PC from Vector 1 (address 4..7). Other do start form some address where the IOC locates a loader record, and so on. Starting from Zero is only one of many ways.

          – Raffzahn
          47 mins ago





          @dashnick Many don't just start, but take a vector form a predefined location like 6500 and 6800 start at the vector residing at FFFE/FF, 68k takes the initial PC from Vector 1 (address 4..7). Other do start form some address where the IOC locates a loader record, and so on. Starting from Zero is only one of many ways.

          – Raffzahn
          47 mins ago




          3




          3





          Intels 8086 employs an interesting combination by starting a offset zero, like 8080/Z80, but in segment FFFF, thus at absolute address FFFF0.

          – Raffzahn
          26 mins ago





          Intels 8086 employs an interesting combination by starting a offset zero, like 8080/Z80, but in segment FFFF, thus at absolute address FFFF0.

          – Raffzahn
          26 mins ago










          Jacob Garby is a new contributor. Be nice, and check out our Code of Conduct.










          draft saved

          draft discarded


















          Jacob Garby is a new contributor. Be nice, and check out our Code of Conduct.













          Jacob Garby is a new contributor. Be nice, and check out our Code of Conduct.












          Jacob Garby is a new contributor. Be nice, and check out our Code of Conduct.
















          Thanks for contributing an answer to Retrocomputing Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fretrocomputing.stackexchange.com%2fquestions%2f9448%2fwhere-does-the-z80-processor-start-executing-from%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Gersau Kjelder | Navigasjonsmeny46°59′0″N 8°31′0″E46°59′0″N...

          Nässjö kommun Tettstader | Kjelder | NavigasjonsmenyeVIAFISNIGeoNamesMusicBrainz (area)

          Kvitkval Innhaldsliste Taksonomi og utvikling | Utsjånad og levevis | Utbreiing | Åtferd |...