Does this PCIe routing look ok?

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
1
down vote

favorite












It is the first time for me to design a PCB with a PCIe bus. My first design failed, the bus is not working!



Tom helped me in this question and instructed me how to correctly route a high speed bus - thanks!
Ethernet controller not recognized on PCIe bus



I now improved my design, but before spending some more hundred bucks I would like to make sure this should work. Does my routing now look ok? Ground planes and ground vias are not shown.



enter image description here










share|improve this question





















  • Have you confirmed the trace width/spacing requirements to make the differential pairs 100 Ohm? The spacing seems to keep changing along the length of the traces.
    – Tom Carpenter
    1 hour ago










  • You can use this tool to work out approximate characteristic impedance.
    – Tom Carpenter
    1 hour ago










  • I know nothing, but shouldn't those vias above the "2" be centred on the traces coming out of them?
    – Andrew Morton
    1 hour ago














up vote
1
down vote

favorite












It is the first time for me to design a PCB with a PCIe bus. My first design failed, the bus is not working!



Tom helped me in this question and instructed me how to correctly route a high speed bus - thanks!
Ethernet controller not recognized on PCIe bus



I now improved my design, but before spending some more hundred bucks I would like to make sure this should work. Does my routing now look ok? Ground planes and ground vias are not shown.



enter image description here










share|improve this question





















  • Have you confirmed the trace width/spacing requirements to make the differential pairs 100 Ohm? The spacing seems to keep changing along the length of the traces.
    – Tom Carpenter
    1 hour ago










  • You can use this tool to work out approximate characteristic impedance.
    – Tom Carpenter
    1 hour ago










  • I know nothing, but shouldn't those vias above the "2" be centred on the traces coming out of them?
    – Andrew Morton
    1 hour ago












up vote
1
down vote

favorite









up vote
1
down vote

favorite











It is the first time for me to design a PCB with a PCIe bus. My first design failed, the bus is not working!



Tom helped me in this question and instructed me how to correctly route a high speed bus - thanks!
Ethernet controller not recognized on PCIe bus



I now improved my design, but before spending some more hundred bucks I would like to make sure this should work. Does my routing now look ok? Ground planes and ground vias are not shown.



enter image description here










share|improve this question













It is the first time for me to design a PCB with a PCIe bus. My first design failed, the bus is not working!



Tom helped me in this question and instructed me how to correctly route a high speed bus - thanks!
Ethernet controller not recognized on PCIe bus



I now improved my design, but before spending some more hundred bucks I would like to make sure this should work. Does my routing now look ok? Ground planes and ground vias are not shown.



enter image description here







pcb routing pcie






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked 1 hour ago









Reto

1274




1274











  • Have you confirmed the trace width/spacing requirements to make the differential pairs 100 Ohm? The spacing seems to keep changing along the length of the traces.
    – Tom Carpenter
    1 hour ago










  • You can use this tool to work out approximate characteristic impedance.
    – Tom Carpenter
    1 hour ago










  • I know nothing, but shouldn't those vias above the "2" be centred on the traces coming out of them?
    – Andrew Morton
    1 hour ago
















  • Have you confirmed the trace width/spacing requirements to make the differential pairs 100 Ohm? The spacing seems to keep changing along the length of the traces.
    – Tom Carpenter
    1 hour ago










  • You can use this tool to work out approximate characteristic impedance.
    – Tom Carpenter
    1 hour ago










  • I know nothing, but shouldn't those vias above the "2" be centred on the traces coming out of them?
    – Andrew Morton
    1 hour ago















Have you confirmed the trace width/spacing requirements to make the differential pairs 100 Ohm? The spacing seems to keep changing along the length of the traces.
– Tom Carpenter
1 hour ago




Have you confirmed the trace width/spacing requirements to make the differential pairs 100 Ohm? The spacing seems to keep changing along the length of the traces.
– Tom Carpenter
1 hour ago












You can use this tool to work out approximate characteristic impedance.
– Tom Carpenter
1 hour ago




You can use this tool to work out approximate characteristic impedance.
– Tom Carpenter
1 hour ago












I know nothing, but shouldn't those vias above the "2" be centred on the traces coming out of them?
– Andrew Morton
1 hour ago




I know nothing, but shouldn't those vias above the "2" be centred on the traces coming out of them?
– Andrew Morton
1 hour ago










1 Answer
1






active

oldest

votes

















up vote
3
down vote













You'll need to confirm the trace width/spacing requirements to make the differential pairs 100 Ohm. You can use this tool to work out approximate characteristic impedance of various trace width/spacing combinations. I'd suggest 8th width, 8th spacing is a good place to start, though you may need to tune those to match your PCB stackup.



Also, in your routing, the spacing seems to keep changing along the length of the traces which will not maintain constant impedance, you must route the traces with the spacing maintained constant along the length.




Having a look at your layout, I have the following comments.



It's worth noting that for starters PCIe doesn't require any specific phase on the reference clock, nor specific biasing on the P and N side for the clock. That means that you are free to swap the P and N lines of the clock without consequence. If you make that swap, your clock routing becomes much simpler as you no longer need to cross over.



Next a little rearranging of your PCIe Tx/Rx lanes allows for a much cleaner routing. The length of the two pairs doesn't need to be the same, so it doesn't matter if the RX pair is much longer or shorter than the TX pair. That means that if you place your AC caps on the bottom for both TX and RX, you can actually route the TX pair all the way around the RX pair, meaning your vias can be placed directly at the connector.



Finally, liberal use of ground vias (shown in the image as green filled vias) is essential, especially placed symmetrically either side or around wherever the differential traces change layer - the ground vias are needed to allow return currents on the reference planes to swap layers.



Based on that, I'd suggest something like the following - though you will need to route it and check design rules as this was hand drawn in paint.



Routing Suggestion






share|improve this answer




















    Your Answer




    StackExchange.ifUsing("editor", function ()
    return StackExchange.using("mathjaxEditing", function ()
    StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
    StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
    );
    );
    , "mathjax-editing");

    StackExchange.ifUsing("editor", function ()
    return StackExchange.using("schematics", function ()
    StackExchange.schematics.init();
    );
    , "cicuitlab");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "135"
    ;
    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',
    convertImagesToLinks: false,
    noModals: false,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













     

    draft saved


    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2felectronics.stackexchange.com%2fquestions%2f399726%2fdoes-this-pcie-routing-look-ok%23new-answer', 'question_page');

    );

    Post as a guest






























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    3
    down vote













    You'll need to confirm the trace width/spacing requirements to make the differential pairs 100 Ohm. You can use this tool to work out approximate characteristic impedance of various trace width/spacing combinations. I'd suggest 8th width, 8th spacing is a good place to start, though you may need to tune those to match your PCB stackup.



    Also, in your routing, the spacing seems to keep changing along the length of the traces which will not maintain constant impedance, you must route the traces with the spacing maintained constant along the length.




    Having a look at your layout, I have the following comments.



    It's worth noting that for starters PCIe doesn't require any specific phase on the reference clock, nor specific biasing on the P and N side for the clock. That means that you are free to swap the P and N lines of the clock without consequence. If you make that swap, your clock routing becomes much simpler as you no longer need to cross over.



    Next a little rearranging of your PCIe Tx/Rx lanes allows for a much cleaner routing. The length of the two pairs doesn't need to be the same, so it doesn't matter if the RX pair is much longer or shorter than the TX pair. That means that if you place your AC caps on the bottom for both TX and RX, you can actually route the TX pair all the way around the RX pair, meaning your vias can be placed directly at the connector.



    Finally, liberal use of ground vias (shown in the image as green filled vias) is essential, especially placed symmetrically either side or around wherever the differential traces change layer - the ground vias are needed to allow return currents on the reference planes to swap layers.



    Based on that, I'd suggest something like the following - though you will need to route it and check design rules as this was hand drawn in paint.



    Routing Suggestion






    share|improve this answer
























      up vote
      3
      down vote













      You'll need to confirm the trace width/spacing requirements to make the differential pairs 100 Ohm. You can use this tool to work out approximate characteristic impedance of various trace width/spacing combinations. I'd suggest 8th width, 8th spacing is a good place to start, though you may need to tune those to match your PCB stackup.



      Also, in your routing, the spacing seems to keep changing along the length of the traces which will not maintain constant impedance, you must route the traces with the spacing maintained constant along the length.




      Having a look at your layout, I have the following comments.



      It's worth noting that for starters PCIe doesn't require any specific phase on the reference clock, nor specific biasing on the P and N side for the clock. That means that you are free to swap the P and N lines of the clock without consequence. If you make that swap, your clock routing becomes much simpler as you no longer need to cross over.



      Next a little rearranging of your PCIe Tx/Rx lanes allows for a much cleaner routing. The length of the two pairs doesn't need to be the same, so it doesn't matter if the RX pair is much longer or shorter than the TX pair. That means that if you place your AC caps on the bottom for both TX and RX, you can actually route the TX pair all the way around the RX pair, meaning your vias can be placed directly at the connector.



      Finally, liberal use of ground vias (shown in the image as green filled vias) is essential, especially placed symmetrically either side or around wherever the differential traces change layer - the ground vias are needed to allow return currents on the reference planes to swap layers.



      Based on that, I'd suggest something like the following - though you will need to route it and check design rules as this was hand drawn in paint.



      Routing Suggestion






      share|improve this answer






















        up vote
        3
        down vote










        up vote
        3
        down vote









        You'll need to confirm the trace width/spacing requirements to make the differential pairs 100 Ohm. You can use this tool to work out approximate characteristic impedance of various trace width/spacing combinations. I'd suggest 8th width, 8th spacing is a good place to start, though you may need to tune those to match your PCB stackup.



        Also, in your routing, the spacing seems to keep changing along the length of the traces which will not maintain constant impedance, you must route the traces with the spacing maintained constant along the length.




        Having a look at your layout, I have the following comments.



        It's worth noting that for starters PCIe doesn't require any specific phase on the reference clock, nor specific biasing on the P and N side for the clock. That means that you are free to swap the P and N lines of the clock without consequence. If you make that swap, your clock routing becomes much simpler as you no longer need to cross over.



        Next a little rearranging of your PCIe Tx/Rx lanes allows for a much cleaner routing. The length of the two pairs doesn't need to be the same, so it doesn't matter if the RX pair is much longer or shorter than the TX pair. That means that if you place your AC caps on the bottom for both TX and RX, you can actually route the TX pair all the way around the RX pair, meaning your vias can be placed directly at the connector.



        Finally, liberal use of ground vias (shown in the image as green filled vias) is essential, especially placed symmetrically either side or around wherever the differential traces change layer - the ground vias are needed to allow return currents on the reference planes to swap layers.



        Based on that, I'd suggest something like the following - though you will need to route it and check design rules as this was hand drawn in paint.



        Routing Suggestion






        share|improve this answer












        You'll need to confirm the trace width/spacing requirements to make the differential pairs 100 Ohm. You can use this tool to work out approximate characteristic impedance of various trace width/spacing combinations. I'd suggest 8th width, 8th spacing is a good place to start, though you may need to tune those to match your PCB stackup.



        Also, in your routing, the spacing seems to keep changing along the length of the traces which will not maintain constant impedance, you must route the traces with the spacing maintained constant along the length.




        Having a look at your layout, I have the following comments.



        It's worth noting that for starters PCIe doesn't require any specific phase on the reference clock, nor specific biasing on the P and N side for the clock. That means that you are free to swap the P and N lines of the clock without consequence. If you make that swap, your clock routing becomes much simpler as you no longer need to cross over.



        Next a little rearranging of your PCIe Tx/Rx lanes allows for a much cleaner routing. The length of the two pairs doesn't need to be the same, so it doesn't matter if the RX pair is much longer or shorter than the TX pair. That means that if you place your AC caps on the bottom for both TX and RX, you can actually route the TX pair all the way around the RX pair, meaning your vias can be placed directly at the connector.



        Finally, liberal use of ground vias (shown in the image as green filled vias) is essential, especially placed symmetrically either side or around wherever the differential traces change layer - the ground vias are needed to allow return currents on the reference planes to swap layers.



        Based on that, I'd suggest something like the following - though you will need to route it and check design rules as this was hand drawn in paint.



        Routing Suggestion







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 54 mins ago









        Tom Carpenter

        36.3k264110




        36.3k264110



























             

            draft saved


            draft discarded















































             


            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2felectronics.stackexchange.com%2fquestions%2f399726%2fdoes-this-pcie-routing-look-ok%23new-answer', 'question_page');

            );

            Post as a guest













































































            Comments

            Popular posts from this blog

            What does second last employer means? [closed]

            Installing NextGIS Connect into QGIS 3?

            Confectionery