This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Strange Way to Code

I came accross this code fragment when reviewing some sample code for ethernet. Didnt even try to build it. Would the delay function even be called if no executable code is in the body? I would think it would be optimized out under all circumstances? In my opionion, its not the right way to do it anyway...

Just curious ...

static void delay (void) {;};


/*--------------------------- output_MDIO -----------------------------------*/

static void output_MDIO (U32 val, U32 n) {

   /* Output a value to the MII PHY management interface. */
   for (val <<= (32 - n); n; val <<= 1, n--) {
      if (val & 0x80000000) {
         GPIO2->FIOSET = MDIO;
      }
      else {
         GPIO2->FIOCLR = MDIO;
      }
      delay ();
      GPIO2->FIOSET = MDC;
      delay ();
      GPIO2->FIOCLR = MDC;
   }
}

Parents
  • a NOP can be optimized out, and a series of NOP without disabling interrupts suffers from the same problem.

    there are many ways to get around the "optimization" issue here, and some of them are incredibly simple and effective.

    "if the delay must be precise"

    maybe that's the point here: the author may not have wanted / required precise delays here.

Reply
  • a NOP can be optimized out, and a series of NOP without disabling interrupts suffers from the same problem.

    there are many ways to get around the "optimization" issue here, and some of them are incredibly simple and effective.

    "if the delay must be precise"

    maybe that's the point here: the author may not have wanted / required precise delays here.

Children