Suporte a Mapas do Perf
***********************

Em plataformas suportadas (no momento em que este livro foi escrito,
apenas Linux), o tempo de execução pode tirar vantagem dos *arquivos
de mapa perf* para tornar as funções Python visíveis para uma
ferramenta de perfilação externa (como perf). Um processo em execução
pode criar um arquivo no diretório "/tmp", que contém entradas que
podem mapear uma seção de código executável para um nome. Esta
interface é descrita na documentação da ferramenta Linux Perf.

Em Python, essas APIs auxiliares podem ser usadas por bibliotecas e
recursos que dependem da geração de código de máquina dinamicamente.

Observe que manter o *estado de thread anexado* não é necessário para
essas APIs.

int PyUnstable_PerfMapState_Init(void)

   *Esta é uma API Instável. Isso pode se alterado sem aviso em
   lançamentos menores.*

   Abre o arquivo "/tmp/perf-$pid.map", a menos que já esteja aberto,
   e cria uma trava para garantir escritas seguras para thread no
   arquivo (desde que as escritas sejam feitas através de
   "PyUnstable_WritePerfMapEntry()" ). Normalmente, não há necessidade
   de chamar isso explicitamente; basta usar
   "PyUnstable_WritePerfMapEntry()" e ele inicializará o estado na
   primeira chamada.

   Retorna "0" em caso de sucesso, "-1" em caso de falha ao
   criar/abrir o arquivo de mapa de desempenho ou "-2" em caso de
   falha na criação de uma trava. Verifique "errno" para mais
   informações sobre a causa de uma falha.

int PyUnstable_WritePerfMapEntry(const void *code_addr, unsigned int code_size, const char *entry_name)

   *Esta é uma API Instável. Isso pode se alterado sem aviso em
   lançamentos menores.*

   Escreve uma única entrada no arquivo "/tmp/perf-$pid.map". Esta
   função é segura para thread. Aqui está a aparência de um exemplo de
   entrada:

      # endereço  tamanho  nome
      7f3529fcf759 b     py::bar:/run/t.py

   Chamará "PyUnstable_PerfMapState_Init()" antes de escrever a
   entrada, se o arquivo de mapa de desempenho ainda não estiver
   aberto. Retorna "0" em caso de sucesso ou os mesmos códigos de erro
   que "PyUnstable_PerfMapState_Init()" em caso de falha.

void PyUnstable_PerfMapState_Fini(void)

   *Esta é uma API Instável. Isso pode se alterado sem aviso em
   lançamentos menores.*

   Fecha o arquivo de mapa do perf aberto por
   "PyUnstable_PerfMapState_Init()". Isso é chamado pelo próprio tempo
   de execução durante o desligamento do interpretador. Em geral, não
   deve haver motivo para chamar isso explicitamente, exceto para
   lidar com cenários específicos, como bifurcação.
