"It is undefined what will happen if a pointer of some type is converted to void*, and then the void* pointer is converted to a type with a stricter alignment requirement" -C99 rationaleV5.10.pdf
| 
char *loop_ptr;
int * int_ptr;
int *mkVoidPtr(void *v_pointer){
  return v_pointer;
}
int_ptr = mkVoidPtr(loop_ptr);
 | 
In this example the v_pointer might be aligned on a 1 byte boundary. Once it is cast to an int some architectures will require it to be on 4 byte boundaries.  Pointers are often cast because a void* cannot be dereferenced. Careless coding can result in an arbitrary pointer type being used irregardless of its alignment.
List of common alignments for Microsoft, Borland and GNU compilers to x86
| Type | Alignment | 
|---|---|
|   | 1 byte aligned | 
|   | 2 byte aligned | 
|   | 4 byte aligned | 
|   | 4 byte aligned | 
|   | 8 byte on Windows, 4 byte on Linux | 
Make specific functions (avoid use of void*)
| 
int *loop_ptr;
int * int_ptr;
int *loopFunction(int *v_pointer)
{    return v_pointer; }
int_ptr = loopFunction(loop_ptr);
 | 
Accessing a pointer that is no longer on the correct access boundary can cause a program to crash, give wrong information or have slow pointer accesses (if the architecture does not care about alignment).
| Rule | Severity | Likelihood | Remediation Cost | Priority | Level | 
|---|---|---|---|---|---|
| DRAFT | 1 (low) | 2 (probable) | 2 (medium) | P4 | L3 | 
| Bryant, Randal and O'Hallaron, David. \[ 2003 \] 2001 Computer Systems: A Programmer's Perspective. Prentice Hall. ISBN 0-13-034074-X. |