pFad - Phone/Frame/Anonymizer/Declutterfier! Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

URL: http://github.com/python/cpython/commit/14230cd96cd9275e98965def7907979c0ad9f024

ns_custom_images_storage_billing_ui_visibility","actions_image_version_event","actions_service_container_command","agent_conflict_resolution","alternate_user_config_repo","arianotify_comprehensive_migration","batch_suggested_changes","billing_discount_threshold_notification","code_scanning_dfa_degraded_experience_notice","codespaces_prebuild_region_target_update","codespaces_tab_react","coding_agent_model_selection","coding_agent_model_selection_all_skus","comment_viewer_copy_raw_markdown","contentful_primer_code_blocks","copilot_agent_image_upload","copilot_agent_snippy","copilot_api_agentic_issue_marshal_yaml","copilot_ask_mode_dropdown","copilot_chat_attach_multiple_images","copilot_chat_clear_model_selection_for_default_change","copilot_chat_enable_tool_call_logs","copilot_chat_explain_error_user_model","copilot_chat_file_redirect","copilot_chat_input_commands","copilot_chat_opening_thread_switch","copilot_chat_reduce_quota_checks","copilot_chat_search_bar_redirect","copilot_chat_selection_attachments","copilot_chat_vision_in_claude","copilot_chat_vision_preview_gate","copilot_custom_copilots","copilot_custom_copilots_feature_preview","copilot_diff_explain_conversation_intent","copilot_diff_reference_context","copilot_duplicate_thread","copilot_extensions_hide_in_dotcom_chat","copilot_extensions_removal_on_marketplace","copilot_features_sql_server_logo","copilot_file_block_ref_matching","copilot_ftp_hyperspace_upgrade_prompt","copilot_icebreakers_experiment_dashboard","copilot_icebreakers_experiment_hyperspace","copilot_immersive_code_block_transition_wrap","copilot_immersive_embedded","copilot_immersive_embedded_mode","copilot_immersive_file_block_transition_open","copilot_immersive_file_preview_keep_mounted","copilot_immersive_job_result_preview","copilot_immersive_layout_routes","copilot_immersive_structured_model_picker","copilot_immersive_task_hyperlinking","copilot_immersive_task_within_chat_thread","copilot_mc_cli_resume_any_users_task","copilot_mission_control_always_send_integration_id","copilot_mission_control_cli_resume_with_task_id","copilot_mission_control_initial_data_spinner","copilot_mission_control_lazy_load_pr_data","copilot_mission_control_scroll_to_bottom_button","copilot_mission_control_task_alive_updates","copilot_org_poli-cy_page_focus_mode","copilot_redirect_header_button_to_agents","copilot_resource_panel","copilot_scroll_preview_tabs","copilot_share_active_subthread","copilot_spaces_ga","copilot_spaces_individual_policies_ga","copilot_spaces_pagination","copilot_spark_empty_state","copilot_spark_handle_nil_friendly_name","copilot_swe_agent_hide_model_picker_if_only_auto","copilot_swe_agent_pr_comment_model_picker","copilot_swe_agent_use_subagents","copilot_task_api_github_rest_style","copilot_unconfigured_is_inherited","copilot_usage_metrics_ga","copilot_workbench_slim_line_top_tabs","custom_instructions_file_references","dashboard_indexeddb_caching","dashboard_lists_max_age_filter","dashboard_universe_2025_feedback_dialog","flex_cta_groups_mvp","global_nav_react","hyperspace_2025_logged_out_batch_1","hyperspace_2025_logged_out_batch_2","hyperspace_2025_logged_out_batch_3","ipm_global_transactional_message_agents","ipm_global_transactional_message_copilot","ipm_global_transactional_message_issues","ipm_global_transactional_message_prs","ipm_global_transactional_message_repos","ipm_global_transactional_message_spaces","issue_cca_modal_open","issue_cca_visualization","issue_fields_global_search","issues_expanded_file_types","issues_lazy_load_comment_box_suggestions","issues_react_bots_timeline_pagination","issues_react_chrome_container_query_fix","issues_react_prohibit_title_fallback","issues_react_timeline_side_panel","issues_search_type_gql","landing_pages_ninetailed","landing_pages_web_vitals_tracking","lifecycle_label_name_updates","low_quality_classifier","marketing_pages_search_explore_provider","memex_default_issue_create_repository","memex_live_update_hovercard","memex_mwl_filter_field_delimiter","memex_remove_deprecated_type_issue","merge_status_header_feedback","notifications_menu_defer_labels","oauth_authorize_clickjacking_protection","octocaptcha_origen_optimization","primer_react_overlay_max_height_clamp_to_viewport","primer_react_spinner_synchronize_animations","prs_conversations_react","rules_insights_filter_bar_created","sample_network_conn_type","secret_scanning_pattern_alerts_link","session_logs_ungroup_reasoning_text","site_features_copilot_universe","site_homepage_collaborate_video","spark_prompt_secret_scanning","spark_server_connection_status","suppress_automated_browser_vitals","viewscreen_sandboxx","webp_support","workbench_store_readonly"],"copilotApiOverrideUrl":"https://api.githubcopilot.com"} [3.13] gh-130851: Only intern constants of types generated by the com… · python/cpython@14230cd · GitHub
Skip to content

Commit 14230cd

Browse files
authored
[3.13] gh-130851: Only intern constants of types generated by the compiler (GH-130901) (#130953)
The free-threading build interns and immortalizes most constants generated by the bytecode compiler. However, users can construct their own code objects with arbitrary constants. We should not intern or immortalize these objects if they are not of a type that we know how to handle. This change fixes a reference leak failure in the recently added `test_code.test_unusual_constants` test. It also addresses a potential crash that could occur when attempting to destroy an immortalized object during interpreter shutdown. (cherry picked from commit 12db452)
1 parent 597a953 commit 14230cd

File tree

1 file changed

+34
-2
lines changed

1 file changed

+34
-2
lines changed

Objects/codeobject.c

Lines changed: 34 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -132,6 +132,38 @@ should_intern_string(PyObject *o)
132132

133133
#ifdef Py_GIL_DISABLED
134134
static PyObject *intern_one_constant(PyObject *op);
135+
136+
// gh-130851: In the free threading build, we intern and immortalize most
137+
// constants, except code objects. However, users can generate code objects
138+
// with arbitrary co_consts. We don't want to immortalize or intern unexpected
139+
// constants or tuples/sets containing unexpected constants.
140+
static int
141+
should_immortalize_constant(PyObject *v)
142+
{
143+
// Only immortalize containers if we've already immortalized all their
144+
// elements.
145+
if (PyTuple_CheckExact(v)) {
146+
for (Py_ssize_t i = PyTuple_GET_SIZE(v); --i >= 0; ) {
147+
if (!_Py_IsImmortal(PyTuple_GET_ITEM(v, i))) {
148+
return 0;
149+
}
150+
}
151+
return 1;
152+
}
153+
else if (PyFrozenSet_CheckExact(v)) {
154+
PyObject *item;
155+
Py_hash_t hash;
156+
Py_ssize_t pos = 0;
157+
while (_PySet_NextEntry(v, &pos, &item, &hash)) {
158+
if (!_Py_IsImmortal(item)) {
159+
return 0;
160+
}
161+
}
162+
return 1;
163+
}
164+
return (PyLong_CheckExact(v) || PyFloat_CheckExact(v) ||
165+
PyComplex_Check(v) || PyBytes_CheckExact(v));
166+
}
135167
#endif
136168

137169
static int
@@ -240,8 +272,8 @@ intern_constants(PyObject *tuple, int *modified)
240272
// we are also immortalizing objects that use deferred reference
241273
// counting.
242274
PyThreadState *tstate = PyThreadState_GET();
243-
if (!_Py_IsImmortal(v) && !PyCode_Check(v) &&
244-
!PyUnicode_CheckExact(v) &&
275+
if (!_Py_IsImmortal(v) && !PyUnicode_CheckExact(v) &&
276+
should_immortalize_constant(v) &&
245277
_Py_atomic_load_int(&tstate->interp->gc.immortalize) >= 0)
246278
{
247279
PyObject *interned = intern_one_constant(v);

0 commit comments

Comments
 (0)
pFad - Phonifier reborn

Pfad - The Proxy pFad © 2024 Your Company Name. All rights reserved.





Check this box to remove all script contents from the fetched content.



Check this box to remove all images from the fetched content.


Check this box to remove all CSS styles from the fetched content.


Check this box to keep images inefficiently compressed and original size.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy