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

Sd driver hang at enable wide bus check

I make file browser with st32f746 discovery
When some string functions (like strchr strcat) on file path or on some touch pointer
Sddriver stuck at driver initialize and after check I found it stuck at enable widebus 4b and if I cancelled that step in driver or changed to 1 b itworks
I'm sure it is not driver or card problem
It is some pointers or string functions

If any one face like that problem please help

Parents
  • one by one still i'm learning
    let the code run first :) now i decided to depend on malloc to save memory and to build modules with pointer to structs
    i want to malloc array of struct i do this but it look like that it allocated only one item
    ______________________________________________________________________________
    TouchItem *TcArray = (TouchItem *)malloc(TC_COUNT*sizeof(TouchItem));
    _____________________________________________________________________________ is that enough or i have to allocate each item in array ??

    regards

Reply
  • one by one still i'm learning
    let the code run first :) now i decided to depend on malloc to save memory and to build modules with pointer to structs
    i want to malloc array of struct i do this but it look like that it allocated only one item
    ______________________________________________________________________________
    TouchItem *TcArray = (TouchItem *)malloc(TC_COUNT*sizeof(TouchItem));
    _____________________________________________________________________________ is that enough or i have to allocate each item in array ??

    regards

Children
  • This is more C rather than Embedded related

    TouchItem *TcArray = (TouchItem *)malloc(TC_COUNT * sizeof(TouchItem));
    

    This would allocate space for TcArray[0] thru TcArray[TC_COUNT-1]

    If you wanted an array of pointers, and then individually allocate the data structures they point too it would look more like this

    TouchItem **TcArray = (TouchItem **)malloc(TC_COUNT * sizeof(TouchItem *)); // Allocate POINTER space
    
    TcArray[0] = (TouchItem *)malloc(sizeof(TouchItem)); // Allocate a STRUCT and put it's address into the array of pointers
    

  • Note that small microcontrollers and malloc() might not always be a good idea.

    If the data will live through the full lifetime of the program and you already know the number of elements, then the data can be statically allocated and you can have the compiler help you with range checking etc directly when you compile.

    If the data needs to be allocated/freed many times during execution, then you might get memory fragmentation so your program starts to fail with allocations even if the heap actually have enough space free - it's just that the free space has been split into many small fragment that are too small for your request.

    It can be hard to test for potential fragmentation issues since the failures might not be seen until the device has been running for weeks or months. But people can be sad if their alarm clock or microwave oven hangs every three months and they have to remove the battery or unplug the power coord just to force a restart.

    Never switch technology (in this case static -> auto -> dynamic allocation) as a way around a bug instead of actually trying to locate the bug. You should only switch technology if you find that you gain actual advantages - not as a way to randomly rewrite the code until it stops failing.