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?

How to write papers efficiently when English isn't my first language?

Sort a list by elements of another list

Is this version of a gravity generator feasible?

Was Spock the First Vulcan in Starfleet?

Is a stroke of luck acceptable after a series of unfavorable events?

Is there a good way to store credentials outside of a password manager?

How easy is it to start Magic from scratch?

Does "every" first-order theory have a finitely axiomatizable conservative extension?

Avoiding estate tax by giving multiple gifts

Anatomically Correct Strange Women In Ponds Distributing Swords

Method to test if a number is a perfect power?

How long to clear the 'suck zone' of a turbofan after start is initiated?

How do scammers retract money, while you can’t?

I'm in charge of equipment buying but no one's ever happy with what I choose. How to fix this?

Closest Prime Number

Lay out the Carpet

Are student evaluations of teaching assistants read by others in the faculty?

Proof of work - lottery approach

How can a function with a hole (removable discontinuity) equal a function with no hole?

How can I kill an app using Terminal?

Two monoidal structures and copowering

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

How did Arya survive the stabbing?

Type int? vs type int



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?













9















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.
























    9















    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.






















      9












      9








      9








      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 5 hours ago









      Jacob GarbyJacob Garby

      1483




      1483




      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


















          9














          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
            5 hours ago











          • Does anything not start at zero?

            – dashnick
            2 hours ago






          • 7





            @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
            2 hours ago






          • 4





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

            – Raffzahn
            1 hour 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









          9














          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
            5 hours ago











          • Does anything not start at zero?

            – dashnick
            2 hours ago






          • 7





            @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
            2 hours ago






          • 4





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

            – Raffzahn
            1 hour ago















          9














          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
            5 hours ago











          • Does anything not start at zero?

            – dashnick
            2 hours ago






          • 7





            @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
            2 hours ago






          • 4





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

            – Raffzahn
            1 hour ago













          9












          9








          9







          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 4 hours ago









          George Phillips

          3,5211522




          3,5211522










          answered 5 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
            5 hours ago











          • Does anything not start at zero?

            – dashnick
            2 hours ago






          • 7





            @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
            2 hours ago






          • 4





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

            – Raffzahn
            1 hour ago

















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

            – Jacob Garby
            5 hours ago











          • Does anything not start at zero?

            – dashnick
            2 hours ago






          • 7





            @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
            2 hours ago






          • 4





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

            – Raffzahn
            1 hour ago
















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

          – Jacob Garby
          5 hours ago





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

          – Jacob Garby
          5 hours ago













          Does anything not start at zero?

          – dashnick
          2 hours ago





          Does anything not start at zero?

          – dashnick
          2 hours ago




          7




          7





          @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
          2 hours 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
          2 hours ago




          4




          4





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

          – Raffzahn
          1 hour 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
          1 hour 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

          Ружовы пелікан Змест Знешні выгляд | Пашырэнне | Асаблівасці біялогіі | Літаратура | НавігацыяДагледжаная версіяправерана1 зменаДагледжаная версіяправерана1 змена/ 22697590 Сістэматыкана ВіківідахВыявына Вікісховішчы174693363011049382

          ValueError: Error when checking input: expected conv2d_13_input to have shape (3, 150, 150) but got array with shape (150, 150, 3)2019 Community Moderator ElectionError when checking : expected dense_1_input to have shape (None, 5) but got array with shape (200, 1)Error 'Expected 2D array, got 1D array instead:'ValueError: Error when checking input: expected lstm_41_input to have 3 dimensions, but got array with shape (40000,100)ValueError: Error when checking target: expected dense_1 to have shape (7,) but got array with shape (1,)ValueError: Error when checking target: expected dense_2 to have shape (1,) but got array with shape (0,)Keras exception: ValueError: Error when checking input: expected conv2d_1_input to have shape (150, 150, 3) but got array with shape (256, 256, 3)Steps taking too long to completewhen checking input: expected dense_1_input to have shape (13328,) but got array with shape (317,)ValueError: Error when checking target: expected dense_3 to have shape (None, 1) but got array with shape (7715, 40000)Keras exception: Error when checking input: expected dense_input to have shape (2,) but got array with shape (1,)

          Illegal assignment from SObject to ContactFetching String, Id from Map - Illegal Assignment Id to Field / ObjectError: Compile Error: Illegal assignment from String to BooleanError: List has no rows for assignment to SObjectError on Test Class - System.QueryException: List has no rows for assignment to SObjectRemote action problemDML requires SObject or SObject list type error“Illegal assignment from List to List”Test Class Fail: Batch Class: System.QueryException: List has no rows for assignment to SObjectMapping to a user'List has no rows for assignment to SObject' Mystery