ES2733516T3 - Verificación de límites en tiempo de compilación para tipos definidos por el usuario - Google Patents
Verificación de límites en tiempo de compilación para tipos definidos por el usuario Download PDFInfo
- Publication number
- ES2733516T3 ES2733516T3 ES11831155T ES11831155T ES2733516T3 ES 2733516 T3 ES2733516 T3 ES 2733516T3 ES 11831155 T ES11831155 T ES 11831155T ES 11831155 T ES11831155 T ES 11831155T ES 2733516 T3 ES2733516 T3 ES 2733516T3
- Authority
- ES
- Spain
- Prior art keywords
- user
- verification
- code
- memory
- limit
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
- G06F8/43—Checking; Contextual analysis
- G06F8/436—Semantic checking
- G06F8/437—Type checking
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
- G06F8/42—Syntactic analysis
- G06F8/423—Preprocessors
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
- G06F8/44—Encoding
- G06F8/443—Optimisation
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computational Linguistics (AREA)
- Stored Programmes (AREA)
- Devices For Executing Special Programs (AREA)
Applications Claiming Priority (2)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US12/892,291 US8533695B2 (en) | 2010-09-28 | 2010-09-28 | Compile-time bounds checking for user-defined types |
| PCT/US2011/051023 WO2012047447A1 (en) | 2010-09-28 | 2011-09-09 | Compile-time bounds checking for user-defined types |
Publications (1)
| Publication Number | Publication Date |
|---|---|
| ES2733516T3 true ES2733516T3 (es) | 2019-11-29 |
Family
ID=45872016
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| ES11831155T Active ES2733516T3 (es) | 2010-09-28 | 2011-09-09 | Verificación de límites en tiempo de compilación para tipos definidos por el usuario |
Country Status (8)
| Country | Link |
|---|---|
| US (1) | US8533695B2 (enExample) |
| EP (1) | EP2622466B1 (enExample) |
| JP (1) | JP5893038B2 (enExample) |
| KR (1) | KR101786156B1 (enExample) |
| CN (1) | CN102402451B (enExample) |
| CA (1) | CA2810986A1 (enExample) |
| ES (1) | ES2733516T3 (enExample) |
| WO (1) | WO2012047447A1 (enExample) |
Families Citing this family (21)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US8291393B2 (en) * | 2007-08-20 | 2012-10-16 | International Business Machines Corporation | Just-in-time compiler support for interruptible code |
| US10705804B2 (en) * | 2012-02-26 | 2020-07-07 | Logistics Research Centre SIA | Strongly typed metadata access in object oriented programming languages with reflection support |
| US9195442B2 (en) | 2012-07-10 | 2015-11-24 | Oracle International Corporation | System and method for compiling lambda expression in a programming language environment |
| US8954939B2 (en) * | 2012-12-31 | 2015-02-10 | Microsoft Corporation | Extending a development environment |
| US20140196015A1 (en) * | 2013-01-04 | 2014-07-10 | Microsoft Corporation | Declaration of lifetime of resource reference |
| US9098269B2 (en) | 2013-01-04 | 2015-08-04 | Microsoft Technology Licensing, Llc | System and method to ensure resource access safety with immutable object types |
| US9772828B2 (en) * | 2014-04-22 | 2017-09-26 | Oracle International Corporation | Structural identification of dynamically generated, pattern-instantiation, generated classes |
| US9672015B2 (en) * | 2015-09-28 | 2017-06-06 | Semmle Limited | Automatic determination of compiler configuration |
| US9684492B2 (en) | 2015-09-28 | 2017-06-20 | Semmle Limited | Automatic determination of compiler configuration |
| CN110337650A (zh) * | 2017-03-02 | 2019-10-15 | 三菱电机株式会社 | 信息处理装置和访问管理程序 |
| US10706164B2 (en) * | 2017-09-29 | 2020-07-07 | Intel Corporation | Crypto-enforced capabilities for isolation |
| CN108459873B (zh) * | 2018-03-05 | 2021-09-24 | 中国人民解放军国防科技大学 | 一种提高开源代码注释率及注释质量的方法 |
| US11023214B2 (en) * | 2018-07-30 | 2021-06-01 | Roger James Poon | System and method for eliminating runtime out-of-bounds errors and exceptions |
| KR102322965B1 (ko) * | 2020-03-23 | 2021-11-09 | 주식회사 티맥스 소프트 | Transpiler를 통하여 전환된 언어와 source 언어간 범용 런타임 검증 시스템 |
| US10963228B1 (en) * | 2020-12-22 | 2021-03-30 | Temper Systems, Inc. | Preventing garbage object accumulation on minimal runtimes |
| US12487824B2 (en) * | 2021-09-21 | 2025-12-02 | Intel Corporation | Immediate offset of load store and atomic instructions |
| US20230315412A1 (en) * | 2022-03-30 | 2023-10-05 | Microsoft Technology Licensing, Llc | Scalable behavioral interface specification checking |
| US20240104013A1 (en) * | 2022-09-28 | 2024-03-28 | Intel Corporation | Deterministic adjacent overflow detection for slotted memory pointers |
| CN118113291A (zh) * | 2022-11-30 | 2024-05-31 | 华为技术有限公司 | 一种内存安全管理方法及设备 |
| US12450045B2 (en) * | 2023-02-13 | 2025-10-21 | Oracle International Corporation | Modeling java source code in a symbolic description language |
| US12436749B2 (en) * | 2023-03-31 | 2025-10-07 | Veracode, Inc. | Inferring type definitions of user-defined types of variables in application program code |
Family Cites Families (18)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US4584666A (en) | 1984-06-21 | 1986-04-22 | Motorola, Inc. | Method and apparatus for signed and unsigned bounds check |
| US5075845A (en) * | 1989-12-22 | 1991-12-24 | Intel Corporation | Type management and control in an object oriented memory protection mechanism |
| US5644709A (en) | 1994-04-21 | 1997-07-01 | Wisconsin Alumni Research Foundation | Method for detecting computer memory access errors |
| US5694539A (en) * | 1994-08-10 | 1997-12-02 | Intrinsa Corporation | Computer process resource modelling method and apparatus |
| US6014723A (en) | 1996-01-24 | 2000-01-11 | Sun Microsystems, Inc. | Processor with accelerated array access bounds checking |
| JPH10275087A (ja) * | 1997-03-28 | 1998-10-13 | Fujitsu Ltd | コンパイル装置 |
| US6149318A (en) | 1997-04-15 | 2000-11-21 | Samuel C. Kendall | Link-time and run-time error detection, and program instrumentation |
| US6343375B1 (en) | 1998-04-24 | 2002-01-29 | International Business Machines Corporation | Method for optimizing array bounds checks in programs |
| JP3280332B2 (ja) | 1998-07-10 | 2002-05-13 | インターナショナル・ビジネス・マシーンズ・コーポレーション | ループに対するバージョニングを実行する方法及び装置、配列レンジ・チェックに関する情報をベーシック・ブロック内において収集する方法及び装置、配列レンジ・チェックに関する情報を変更する方法、配列レンジ・チェック最適化方法、配列レンジ・チェックのためのコードを生成する方法、不要配列レンジ・チェック除去方法及び装置、配列レンジ・チェックを選択する方法、配列レンジ・チェック変更方法、配列レンジ・チェック収集方法、及び配列レンジ・チェック取扱判断方法 |
| US7260817B2 (en) * | 1999-07-09 | 2007-08-21 | International Business Machines Corporation | Method using array range check information for generating versioning code before a loop for execution |
| JP3564445B2 (ja) * | 2001-09-20 | 2004-09-08 | 松下電器産業株式会社 | プロセッサ、コンパイル装置及びコンパイル方法 |
| WO2005029241A2 (en) | 2003-09-15 | 2005-03-31 | Plum Thomas S | Automated safe secure techniques for eliminating |
| US20050108695A1 (en) * | 2003-11-14 | 2005-05-19 | Long Li | Apparatus and method for an automatic thread-partition compiler |
| US7448029B2 (en) * | 2004-04-26 | 2008-11-04 | International Business Machines Corporation | Modification of array access checking in AIX |
| US7325007B2 (en) * | 2005-03-07 | 2008-01-29 | Microsoft Corporation | System and method for supporting non-native data types in a database API |
| US7650346B2 (en) * | 2005-04-01 | 2010-01-19 | Microsoft Corporation | User-defined type consistency checker |
| US7747565B2 (en) * | 2005-12-07 | 2010-06-29 | Microsoft Corporation | Garbage collector support for transactional memory |
| US8484613B2 (en) * | 2010-01-28 | 2013-07-09 | Synopsys, Inc. | Optimizing bounds checking using computer algebra |
-
2010
- 2010-09-28 US US12/892,291 patent/US8533695B2/en not_active Expired - Fee Related
-
2011
- 2011-09-09 CA CA2810986A patent/CA2810986A1/en not_active Abandoned
- 2011-09-09 JP JP2013531616A patent/JP5893038B2/ja not_active Expired - Fee Related
- 2011-09-09 KR KR1020137007833A patent/KR101786156B1/ko not_active Expired - Fee Related
- 2011-09-09 EP EP11831155.4A patent/EP2622466B1/en active Active
- 2011-09-09 ES ES11831155T patent/ES2733516T3/es active Active
- 2011-09-09 WO PCT/US2011/051023 patent/WO2012047447A1/en not_active Ceased
- 2011-09-26 CN CN201110306863.8A patent/CN102402451B/zh not_active Expired - Fee Related
Also Published As
| Publication number | Publication date |
|---|---|
| EP2622466A1 (en) | 2013-08-07 |
| KR101786156B1 (ko) | 2017-10-16 |
| CN102402451B (zh) | 2014-07-23 |
| US8533695B2 (en) | 2013-09-10 |
| JP2013539130A (ja) | 2013-10-17 |
| JP5893038B2 (ja) | 2016-03-23 |
| US20120079465A1 (en) | 2012-03-29 |
| KR20130101037A (ko) | 2013-09-12 |
| CA2810986A1 (en) | 2012-04-12 |
| EP2622466A4 (en) | 2014-10-01 |
| CN102402451A (zh) | 2012-04-04 |
| EP2622466B1 (en) | 2019-04-10 |
| WO2012047447A1 (en) | 2012-04-12 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| ES2733516T3 (es) | Verificación de límites en tiempo de compilación para tipos definidos por el usuario | |
| US10152309B2 (en) | Cross-library framework architecture feature sets | |
| US10747511B2 (en) | Compiler optimization of coroutines | |
| Treichler et al. | Language support for dynamic, hierarchical data partitioning | |
| US20140040856A1 (en) | Apparatus, Method and System for Building Software by Composition | |
| US8843920B2 (en) | Systems and methods for deferring software implementation decisions until load time | |
| CN107273109B (zh) | 对源代码建模的方法和系统以及使用数据模型的方法 | |
| CN118202330A (zh) | 在代码更新时检查源代码有效性 | |
| US20080052693A1 (en) | Method of simd-ization through data reshaping, padding, and alignment | |
| CN107003885B (zh) | 用于低级别可组合高性能计算库的技术 | |
| US9141356B2 (en) | Process for generating dynamic type | |
| Hong et al. | Improving simd parallelism via dynamic binary translation | |
| Wilkins et al. | Warden: Specializing cache coherence for high-level parallel languages | |
| US9135027B1 (en) | Code generation and execution for dynamic programming languages | |
| Lattner et al. | Data structure analysis: An efficient context-sensitive heap analysis | |
| CN119440672B (zh) | 函数库链接方法、装置、设备、存储介质及程序产品 | |
| CN105393216B (zh) | 运行时内存调节 | |
| Dillig et al. | SAIL: Static analysis intermediate language with a two-level representation | |
| Mandrykin et al. | A memory model for deductively verifying Linux kernel modules | |
| Gurajada | System Programming | |
| CN120687075A (zh) | 面向异构多核处理器的代码划分方法、系统、设备及介质 | |
| Saiu | GNU Jitter | |
| Simpson | Runtime enforcement of memory safety for the C programming language | |
| Azevedo et al. | An Annotation-aware JVM Implementation | |
| Kastinger | Piero Ploner (pploner@ cosy. sbg. ac. at), Michael Wallner (mwallner@ cosy. sbg. ac. at) University of Salzburg, Department of Computer Sciences |