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 a trava global do interpretador (GIL) 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 dePyUnstable_WritePerfMapEntry()
). Normalmente, não há necessidade de chamar isso explicitamente; basta usarPyUnstable_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. Verifiqueerrno
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. Retorna0
em caso de sucesso ou os mesmos códigos de erro quePyUnstable_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.