Verifique se uma sequência é palíndromo em C

Eu tenho uma pergunta sobre esse código que estou escrevendo para um exercício. Eu tenho que verificar se uma string é palíndromo. Não consigo alterar a declaração da função. A função só retorna 1 quando todas as letras são iguais (como "aaaa"), mas se eu cobrar a frase com outro palíndromo (como "anna"), a função retornará 0, Eu não consigo descobrir por que esse appening.Thank você!

char* cargar (char*);
int pali (char*);

int main()
{ 
   char*texto=NULL;
   texto=cargar(texto);
   int res=pali(texto);
   if(res==1){printf("\nPalindrome");}
   else printf("\nNot palindrome");

   return 0;
}

char* cargar (char*texto)
{
   char letra;
   int i=0;
   texto=malloc(sizeof(char));
   letra=getche();
   *(texto+i)=letra;
   while(letra!='\r'){
      i++;
      texto=realloc(texto,(i+1)*sizeof(char));
      letra=getche();
      *(texto+i)=letra;}
   *(texto+i)='\0';      
   return texto;
}

int pali (char* texto)
{
   int i;
   for(i=0;*(texto+i)!='\0';i++){
   }i--;
   if(i==0||i==1){return 1;}

   if(*texto==*(texto+i)){
      return pali(++texto);
   }
   else return 0;
}

questionAnswers(3)

yourAnswerToTheQuestion